mirror of
https://github.com/wabbajack-tools/wabbajack.git
synced 2024-08-30 18:42:17 +00:00
Merge pull request #1867 from wabbajack-tools/all-logins
Add LoversLab and VectorPlexus logins
This commit is contained in:
commit
9fd2542e77
@ -74,6 +74,8 @@ public partial class App
|
|||||||
services.AddBlazoredToast();
|
services.AddBlazoredToast();
|
||||||
services.AddTransient<MainWindow>();
|
services.AddTransient<MainWindow>();
|
||||||
services.AddTransient<NexusLogin>();
|
services.AddTransient<NexusLogin>();
|
||||||
|
services.AddTransient<VectorPlexus>();
|
||||||
|
services.AddTransient<LoversLab>();
|
||||||
services.AddSingleton<SystemParametersConstructor>();
|
services.AddSingleton<SystemParametersConstructor>();
|
||||||
services.AddSingleton<IStateContainer, StateContainer>();
|
services.AddSingleton<IStateContainer, StateContainer>();
|
||||||
return services;
|
return services;
|
||||||
|
@ -31,6 +31,14 @@ public abstract class BrowserTabViewModel : ViewModel
|
|||||||
|
|
||||||
protected abstract Task Run(CancellationToken token);
|
protected abstract Task Run(CancellationToken token);
|
||||||
|
|
||||||
|
protected async Task WaitForReady()
|
||||||
|
{
|
||||||
|
while (Browser?.Browser.CoreWebView2 == null)
|
||||||
|
{
|
||||||
|
await Task.Delay(250);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public async Task NavigateTo(Uri uri)
|
public async Task NavigateTo(Uri uri)
|
||||||
{
|
{
|
||||||
var tcs = new TaskCompletionSource();
|
var tcs = new TaskCompletionSource();
|
||||||
|
100
Wabbajack.App.Blazor/Browser/ViewModels/IPSOAuth2Login.cs
Normal file
100
Wabbajack.App.Blazor/Browser/ViewModels/IPSOAuth2Login.cs
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Net.Http;
|
||||||
|
using System.Net.Http.Json;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Web;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Wabbajack.DTOs.Logins;
|
||||||
|
using Wabbajack.Services.OSIntegrated;
|
||||||
|
|
||||||
|
namespace Wabbajack.App.Blazor.Browser.ViewModels;
|
||||||
|
|
||||||
|
public abstract class IPSOAuth2Login<TLoginType> : BrowserTabViewModel
|
||||||
|
where TLoginType : OAuth2LoginState, new()
|
||||||
|
{
|
||||||
|
private readonly HttpClient _httpClient;
|
||||||
|
private readonly EncryptedJsonTokenProvider<TLoginType> _tokenProvider;
|
||||||
|
private readonly ILogger _logger;
|
||||||
|
|
||||||
|
public IPSOAuth2Login(ILogger logger, HttpClient httpClient,
|
||||||
|
EncryptedJsonTokenProvider<TLoginType> tokenProvider)
|
||||||
|
{
|
||||||
|
var tlogin = new TLoginType();
|
||||||
|
HeaderText = $"{tlogin.SiteName} Login";
|
||||||
|
_logger = logger;
|
||||||
|
_httpClient = httpClient;
|
||||||
|
_tokenProvider = tokenProvider;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override async Task Run(CancellationToken token)
|
||||||
|
{
|
||||||
|
var tlogin = new TLoginType();
|
||||||
|
|
||||||
|
var tcs = new TaskCompletionSource<Uri>();
|
||||||
|
await WaitForReady();
|
||||||
|
Browser!.Browser.CoreWebView2.Settings.UserAgent = "Wabbajack";
|
||||||
|
Browser!.Browser.NavigationStarting += (sender, args) =>
|
||||||
|
{
|
||||||
|
var uri = new Uri(args.Uri);
|
||||||
|
if (uri.Scheme == "wabbajack")
|
||||||
|
{
|
||||||
|
tcs.TrySetResult(uri);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Instructions = $"Please log in and allow Wabbajack to access your {tlogin.SiteName} account";
|
||||||
|
|
||||||
|
var scopes = string.Join(" ", tlogin.Scopes);
|
||||||
|
var state = Guid.NewGuid().ToString();
|
||||||
|
|
||||||
|
await NavigateTo(new Uri(tlogin.AuthorizationEndpoint +
|
||||||
|
$"?response_type=code&client_id={tlogin.ClientID}&state={state}&scope={scopes}"));
|
||||||
|
|
||||||
|
var uri = await tcs.Task.WaitAsync(token);
|
||||||
|
|
||||||
|
var cookies = await GetCookies(tlogin.AuthorizationEndpoint.Host, token);
|
||||||
|
|
||||||
|
var parsed = HttpUtility.ParseQueryString(uri.Query);
|
||||||
|
if (parsed.Get("state") != state)
|
||||||
|
{
|
||||||
|
_logger.LogCritical("Bad OAuth state, this shouldn't happen");
|
||||||
|
throw new Exception("Bad OAuth State");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parsed.Get("code") == null)
|
||||||
|
{
|
||||||
|
_logger.LogCritical("Bad code result from OAuth");
|
||||||
|
throw new Exception("Bad code result from OAuth");
|
||||||
|
}
|
||||||
|
|
||||||
|
var authCode = parsed.Get("code");
|
||||||
|
|
||||||
|
var formData = new KeyValuePair<string?, string?>[]
|
||||||
|
{
|
||||||
|
new("grant_type", "authorization_code"),
|
||||||
|
new("code", authCode),
|
||||||
|
new("client_id", tlogin.ClientID)
|
||||||
|
};
|
||||||
|
|
||||||
|
var msg = new HttpRequestMessage();
|
||||||
|
msg.Method = HttpMethod.Post;
|
||||||
|
msg.RequestUri = tlogin.TokenEndpoint;
|
||||||
|
msg.Headers.Add("User-Agent",
|
||||||
|
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36");
|
||||||
|
msg.Headers.Add("Cookie", string.Join(";", cookies.Select(c => $"{c.Name}={c.Value}")));
|
||||||
|
msg.Content = new FormUrlEncodedContent(formData.ToList());
|
||||||
|
|
||||||
|
using var response = await _httpClient.SendAsync(msg, token);
|
||||||
|
var data = await response.Content.ReadFromJsonAsync<OAuthResultState>(cancellationToken: token);
|
||||||
|
|
||||||
|
await _tokenProvider.SetToken(new TLoginType
|
||||||
|
{
|
||||||
|
Cookies = cookies,
|
||||||
|
ResultState = data!
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
15
Wabbajack.App.Blazor/Browser/ViewModels/LoversLab.cs
Normal file
15
Wabbajack.App.Blazor/Browser/ViewModels/LoversLab.cs
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
using System.Net.Http;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Wabbajack.DTOs.DownloadStates;
|
||||||
|
using Wabbajack.DTOs.Logins;
|
||||||
|
using Wabbajack.Services.OSIntegrated;
|
||||||
|
|
||||||
|
namespace Wabbajack.App.Blazor.Browser.ViewModels;
|
||||||
|
|
||||||
|
public class LoversLab : IPSOAuth2Login<LoversLabLoginState>
|
||||||
|
{
|
||||||
|
public LoversLab(ILogger<LoversLab> logger, HttpClient httpClient, EncryptedJsonTokenProvider<LoversLabLoginState> tokenProvider)
|
||||||
|
: base(logger, httpClient, tokenProvider)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
14
Wabbajack.App.Blazor/Browser/ViewModels/VectorPlexus.cs
Normal file
14
Wabbajack.App.Blazor/Browser/ViewModels/VectorPlexus.cs
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
using System.Net.Http;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Wabbajack.DTOs.Logins;
|
||||||
|
using Wabbajack.Services.OSIntegrated;
|
||||||
|
|
||||||
|
namespace Wabbajack.App.Blazor.Browser.ViewModels;
|
||||||
|
|
||||||
|
public class VectorPlexus : IPSOAuth2Login<VectorPlexusLoginState>
|
||||||
|
{
|
||||||
|
public VectorPlexus(ILogger<VectorPlexus> logger, HttpClient httpClient, EncryptedJsonTokenProvider<VectorPlexusLoginState> tokenProvider)
|
||||||
|
: base(logger, httpClient, tokenProvider)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
@ -11,6 +11,9 @@
|
|||||||
<div class="resources">
|
<div class="resources">
|
||||||
|
|
||||||
<button onclick="@LoginToNexus">Login To Nexus</button>
|
<button onclick="@LoginToNexus">Login To Nexus</button>
|
||||||
|
<button onclick="@LoginToVectorPlexus">Login To Vector Plexus</button>
|
||||||
|
<button onclick="@LoginToLoversLab">Login To Lovers Lab</button>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -21,4 +24,12 @@
|
|||||||
{
|
{
|
||||||
MessageBus.Current.SendMessage(new OpenBrowserTab(_serviceProvider.GetRequiredService<NexusLogin>()));
|
MessageBus.Current.SendMessage(new OpenBrowserTab(_serviceProvider.GetRequiredService<NexusLogin>()));
|
||||||
}
|
}
|
||||||
|
public void LoginToLoversLab()
|
||||||
|
{
|
||||||
|
MessageBus.Current.SendMessage(new OpenBrowserTab(_serviceProvider.GetRequiredService<LoversLab>()));
|
||||||
|
}
|
||||||
|
public void LoginToVectorPlexus()
|
||||||
|
{
|
||||||
|
MessageBus.Current.SendMessage(new OpenBrowserTab(_serviceProvider.GetRequiredService<VectorPlexus>()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user