mirror of
https://github.com/btcpayserver/btcpayserver.git
synced 2025-01-18 21:32:27 +01:00
e43b4ed540
* Server Users: More precise message when inviting users This lets the admin who invited a new user know whether or not an email has been sent. If the SMTP server hasn't been set up, they need to share the invite link with the user. * Onboarding: Invite new users - Separates the user self-registration and invite cases - Adds invitation email for users created by the admin - Adds invitation tokens to verify user was invited - Adds handler action for invite links - Refactors `UserEventHostedService` * Remove duplicate status message from views that use the wizard layout * Auto-approve users created by an admin * Notify admins via email if a new account requires approval * Update wording * Fix update user error * Fix redirect to email confirmation in invite action * Fix precondition checks after signup * Improve admin notification Send notification only if the user does not require email confirmation or when they confirmed their email address. Rationale: We want to inform admins only about qualified users and not annoy them with bot registrations. * Allow approval alongside resending confirm email * Use user email in log messages instead of ID * Prevent unnecessary notification after email confirmation * Use ApplicationUser type explicitly * Fix after rebase * Refactoring: Do not subclass UserRegisteredEvent
27 lines
917 B
C#
27 lines
917 B
C#
using System;
|
|
using Microsoft.AspNetCore.DataProtection;
|
|
using Microsoft.AspNetCore.Identity;
|
|
using Microsoft.Extensions.Logging;
|
|
using Microsoft.Extensions.Options;
|
|
|
|
namespace BTCPayServer.Security;
|
|
|
|
// https://andrewlock.net/implementing-custom-token-providers-for-passwordless-authentication-in-asp-net-core-identity/
|
|
public class InvitationTokenProviderOptions : DataProtectionTokenProviderOptions
|
|
{
|
|
public const string ProviderName = "InvitationTokenProvider";
|
|
|
|
public InvitationTokenProviderOptions()
|
|
{
|
|
Name = ProviderName;
|
|
TokenLifespan = TimeSpan.FromDays(7);
|
|
}
|
|
}
|
|
|
|
public class InvitationTokenProvider<TUser>(
|
|
IDataProtectionProvider dataProtectionProvider,
|
|
IOptions<InvitationTokenProviderOptions> options,
|
|
ILogger<DataProtectorTokenProvider<TUser>> logger)
|
|
: DataProtectorTokenProvider<TUser>(dataProtectionProvider, options, logger)
|
|
where TUser : class;
|