62 lines
2.5 KiB
C#
62 lines
2.5 KiB
C#
|
using System;
|
|||
|
using Forum.DataAccessLayer.Models;
|
|||
|
using Forum.DataAccessLayer.Services;
|
|||
|
|
|||
|
namespace Forum.DataAccessLayer.Managers
|
|||
|
{
|
|||
|
public class ApplicationUserManager : UserManager<ProfessionalUser>
|
|||
|
{
|
|||
|
public ApplicationUserManager(IUserStore<ProfessionalUser> store)
|
|||
|
: base(store)
|
|||
|
{
|
|||
|
}
|
|||
|
|
|||
|
public static ApplicationUserManager Create(IdentityFactoryOptions<ApplicationUserManager> options, IOwinContext context)
|
|||
|
{
|
|||
|
var manager = new ApplicationUserManager(new UserStore<ProfessionalUser>(context.Get<ApplicationDbContext>()));
|
|||
|
// Configure validation logic for usernames
|
|||
|
manager.UserValidator = new UserValidator<ProfessionalUser>(manager)
|
|||
|
{
|
|||
|
AllowOnlyAlphanumericUserNames = false,
|
|||
|
RequireUniqueEmail = true
|
|||
|
};
|
|||
|
|
|||
|
// Configure validation logic for passwords
|
|||
|
manager.PasswordValidator = new PasswordValidator
|
|||
|
{
|
|||
|
RequiredLength = 6,
|
|||
|
RequireNonLetterOrDigit = true,
|
|||
|
RequireDigit = true,
|
|||
|
RequireLowercase = true,
|
|||
|
RequireUppercase = true,
|
|||
|
};
|
|||
|
|
|||
|
// Configure user lockout defaults
|
|||
|
manager.UserLockoutEnabledByDefault = true;
|
|||
|
manager.DefaultAccountLockoutTimeSpan = TimeSpan.FromMinutes(5);
|
|||
|
manager.MaxFailedAccessAttemptsBeforeLockout = 5;
|
|||
|
|
|||
|
// Register two factor authentication providers. This application uses Phone and Emails as a step of receiving a code for verifying the user
|
|||
|
// You can write your own provider and plug it in here.
|
|||
|
manager.RegisterTwoFactorProvider("Phone Code", new PhoneNumberTokenProvider<ProfessionalUser>
|
|||
|
{
|
|||
|
MessageFormat = "Your security code is {0}"
|
|||
|
});
|
|||
|
manager.RegisterTwoFactorProvider("Email Code", new EmailTokenProvider<ProfessionalUser>
|
|||
|
{
|
|||
|
Subject = "Security Code",
|
|||
|
BodyFormat = "Your security code is {0}"
|
|||
|
});
|
|||
|
manager.EmailService = new EmailService();
|
|||
|
manager.SmsService = new SmsService();
|
|||
|
var dataProtectionProvider = options.DataProtectionProvider;
|
|||
|
if (dataProtectionProvider != null)
|
|||
|
{
|
|||
|
manager.UserTokenProvider =
|
|||
|
new DataProtectorTokenProvider<ProfessionalUser>(dataProtectionProvider.Create("ASP.NET Identity"));
|
|||
|
}
|
|||
|
return manager;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|