Added custom scheme

This commit is contained in:
Max 2024-07-13 16:27:45 +02:00
parent de656cc2e8
commit 5341179e94
5 changed files with 74 additions and 16 deletions

View File

@ -1,20 +1,24 @@
using System.Security.Claims;
using DotBased.Logging;
using Microsoft.AspNetCore.Components.Authorization;
namespace DotBased.ASP.Auth;
// RevalidatingServerAuthenticationStateProvider
public class BasedAuthenticationStateProvider : AuthenticationStateProvider
{
public BasedAuthenticationStateProvider()
public BasedAuthenticationStateProvider(BasedAuthConfiguration configuration)
{
_config = configuration;
_logger = LogService.RegisterLogger(typeof(BasedAuthenticationStateProvider));
}
private BasedAuthConfiguration _config;
private ILogger _logger;
private AuthenticationState _anonState = new AuthenticationState(new ClaimsPrincipal(new ClaimsIdentity(new List<Claim>() {new Claim(ClaimTypes.Role, "test")})));
public override Task<AuthenticationState> GetAuthenticationStateAsync()
{
throw new NotImplementedException();
return Task.FromResult(_anonState);
}
}

View File

@ -1,13 +0,0 @@
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Components.Authorization;
using Microsoft.Extensions.DependencyInjection;
namespace DotBased.ASP.Auth;
public static class DotBasedASPAuth
{
public static void UseBasedAuth(this WebApplicationBuilder builder, BasedAuthConfiguration configuration)
{
builder.Services.AddScoped<AuthenticationStateProvider, BasedAuthenticationStateProvider>();
}
}

View File

@ -0,0 +1,28 @@
using DotBased.ASP.Auth.Scheme;
using Microsoft.AspNetCore.Components.Authorization;
using Microsoft.Extensions.DependencyInjection;
namespace DotBased.ASP.Auth;
public static class DotBasedAuthDependencyInjection
{
/// <summary>
/// Use the DotBased authentication implementation
/// </summary>
/// <remarks>Use the app.UseAuthentication() and app.UseAuthorization()!</remarks>
/// <param name="services">Service colllection</param>
/// <param name="configurationAction">DotBased auth configuration</param>
public static void UseBasedAuth(this IServiceCollection services, Action<BasedAuthConfiguration>? configurationAction = null)
{
var config = new BasedAuthConfiguration();
configurationAction?.Invoke(config);
services.AddSingleton<BasedAuthConfiguration>(config);
services.AddScoped<AuthenticationStateProvider, BasedAuthenticationStateProvider>();
services.AddAuthentication(options =>
{
options.DefaultScheme = BasedAuthenticationHandler.AuthenticationScheme;
}).AddScheme<BasedAuthenticationHandlerOptions, BasedAuthenticationHandler>(BasedAuthenticationHandler.AuthenticationScheme, null);
services.AddAuthorization();
}
}

View File

@ -0,0 +1,31 @@
using System.Security.Claims;
using System.Text.Encodings.Web;
using Microsoft.AspNetCore.Authentication;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
namespace DotBased.ASP.Auth.Scheme;
public class BasedAuthenticationHandler : AuthenticationHandler<BasedAuthenticationHandlerOptions>
{
public const string AuthenticationScheme = "DotBasedAuthentication";
#pragma warning disable CS0618 // Type or member is obsolete
public BasedAuthenticationHandler(IOptionsMonitor<BasedAuthenticationHandlerOptions> options, ILoggerFactory logger, UrlEncoder encoder, ISystemClock clock) : base(options, logger, encoder, clock)
#pragma warning restore CS0618 // Type or member is obsolete
{
}
public BasedAuthenticationHandler(IOptionsMonitor<BasedAuthenticationHandlerOptions> options, ILoggerFactory logger, UrlEncoder encoder) : base(options, logger, encoder)
{
}
protected override Task<AuthenticateResult> HandleAuthenticateAsync()
{
var principal = new ClaimsPrincipal(new ClaimsIdentity(new List<Claim>() { new Claim(ClaimTypes.Role, "Admin"), new Claim(ClaimTypes.Name, "Anon") }, AuthenticationScheme));
var ticket = new AuthenticationTicket(principal, AuthenticationScheme);
return Task.FromResult(AuthenticateResult.Success(ticket));
}
}

View File

@ -0,0 +1,8 @@
using Microsoft.AspNetCore.Authentication;
namespace DotBased.ASP.Auth.Scheme;
public class BasedAuthenticationHandlerOptions : AuthenticationSchemeOptions
{
}