DotBased/DotBased.ASP.Auth/BasedAuthConfiguration.cs

65 lines
2.2 KiB
C#
Raw Normal View History

2024-07-07 17:41:54 +02:00
namespace DotBased.ASP.Auth;
public class BasedAuthConfiguration
{
/// <summary>
/// Allow users to registrate.
2024-07-07 17:41:54 +02:00
/// </summary>
public bool AllowRegistration { get; set; }
//TODO: Callback when a user registers, so the application can handle sending emails or generate a code to complete the registration.
2024-07-27 16:07:13 +02:00
//TODO: Callback for validation email, phone number
/// <summary>
/// Allow no passwords on users, not recommended!
/// </summary>
public bool AllowEmptyPassword { get; set; } = false;
/// <summary>
/// This path is used for redirecting to the login page.
/// </summary>
2024-07-07 17:41:54 +02:00
public string LoginPath { get; set; } = string.Empty;
2024-07-27 16:07:13 +02:00
/// <summary>
/// The path that will be used if the logout is requested.
/// </summary>
2024-07-07 17:41:54 +02:00
public string LogoutPath { get; set; } = string.Empty;
/// <summary>
2024-11-02 01:57:25 +01:00
/// The page that the client will be redirected to after logging out.
/// </summary>
public string LoggedOutPath { get; set; } = string.Empty;
/// <summary>
2024-07-07 17:41:54 +02:00
/// The max age before a AuthenticationState will expire (default: 7 days).
/// </summary>
public TimeSpan AuthenticationStateMaxAgeBeforeExpire { get; set; } = TimeSpan.FromDays(7);
2024-07-27 16:07:13 +02:00
/// <summary>
2024-09-27 02:38:18 +02:00
/// How long a session state will be cached (default: 15 min)
/// </summary>
public TimeSpan CachedAuthSessionLifespan { get; set; } = TimeSpan.FromMinutes(15);
/// <summary>
2024-07-27 16:07:13 +02:00
/// Can be used to seed a default user and/or group for first time use.
/// </summary>
2024-09-27 02:38:18 +02:00
public Action<IAuthDataRepository>? SeedData { get; set; }
2024-07-27 16:07:13 +02:00
2024-09-27 02:38:18 +02:00
public Type? AuthDataRepositoryType { get; private set; }
2024-07-27 16:07:13 +02:00
2024-09-27 02:38:18 +02:00
public void SetDataRepositoryType<TDataProviderType>() where TDataProviderType : IAuthDataRepository =>
AuthDataRepositoryType = typeof(TDataProviderType);
2024-07-27 16:07:13 +02:00
public Type? SessionStateProviderType { get; private set; }
public void SetSessionStateProviderType<TSessionStateProviderType>()
where TSessionStateProviderType : ISessionStateProvider =>
SessionStateProviderType = typeof(TSessionStateProviderType);
2024-12-01 03:13:55 +01:00
}
public class BasedPasswordOptions
{
}
public class BasedUserOptions
{
}
public class BasedLockoutOptions
{
2024-07-07 17:41:54 +02:00
}