Neighbourhood.omg.lol/LoginWebViewPage.xaml.cs

59 lines
2.1 KiB
C#
Raw Normal View History

using Microsoft.AspNetCore.Components;
using Microsoft.AspNetCore.Components.Authorization;
using System.Diagnostics;
using System.Web;
2024-06-05 12:41:08 +00:00
using Microsoft.Extensions.Configuration;
namespace Neighbourhood.omg.lol;
public partial class LoginWebViewPage : ContentPage
{
private AuthenticationStateProvider AuthStateProvider { get; set; }
private NavigatorService NavigatorService { get; set; }
2024-06-05 12:41:08 +00:00
private IConfiguration Configuration { get; set; }
private RestService api { get; set; }
2024-06-05 12:41:08 +00:00
private string? client_id;
private string? client_secret;
private string? redirect_uri;
public LoginWebViewPage(AuthenticationStateProvider authStateProvider, NavigatorService navigatorService, IConfiguration configuration, RestService restService)
{
2024-06-05 12:41:08 +00:00
this.AuthStateProvider = authStateProvider;
this.NavigatorService = navigatorService;
2024-06-05 12:41:08 +00:00
this.Configuration = configuration;
this.api = restService;
InitializeComponent();
2024-06-05 12:41:08 +00:00
client_id = configuration.GetValue<string>("client_id");
client_secret = configuration.GetValue<string>("client_secret");
redirect_uri = configuration.GetValue<string>("redirect_uri");
2024-06-05 12:41:08 +00:00
// make sure they're all not null first.
if ( client_id != null
&& client_secret != null
&& redirect_uri != null) {
this.loginwebview.Source = $"https://home.omg.lol/oauth/authorize?client_id={client_id}&scope=everything&redirect_uri={redirect_uri}&response_type=code";
}
}
public async void loginwebview_Navigating(object sender, WebNavigatingEventArgs e) {
2024-06-05 12:41:08 +00:00
if ( client_id != null
&& client_secret != null
&& redirect_uri != null
&& e.Url.StartsWith(redirect_uri))
{
Uri uri = new Uri(e.Url);
var query = HttpUtility.ParseQueryString(uri.Query);
string? code = query.Get("code");
if (!string.IsNullOrEmpty(code)) {
2024-06-05 12:41:08 +00:00
string? token = await api.OAuth(code, client_id, client_secret, redirect_uri);
if (!string.IsNullOrEmpty(token)) {
await ((CustomAuthenticationStateProvider)this.AuthStateProvider).Login(token);
NavigatorService.NavigationManager.NavigateTo(NavigatorService.NavigationManager.Uri, forceLoad: true);
await Shell.Current.GoToAsync("..");
}
}
}
}
}