/// <summary> /// Constructor method. /// </summary> public AccountController(AdminUserManager adminUserManager, AdminSignInManager adminSignInManager, IAuthenticationManager authenticationManager, IEmailDispatcherService emailDispatcherService) { _adminUserManager = adminUserManager ?? throw new ArgumentNullException(nameof(adminUserManager), nameof(AccountController)); _adminSignInManager = adminSignInManager ?? throw new ArgumentNullException(nameof(adminSignInManager), nameof(AccountController)); _authenticationManager = authenticationManager ?? throw new ArgumentNullException(nameof(authenticationManager), nameof(AccountController)); _emailDispatcherService = emailDispatcherService ?? throw new ArgumentNullException(nameof(emailDispatcherService), nameof(AccountController)); }
public async Task <ActionResult> Login(LoginViewModel model) { if (!ModelState.IsValid) { return(View(model)); } // This doesn't count login failures towards account lockout // To enable password failures to trigger account lockout, change to shouldLockout: true var result = await AdminSignInManager.PasswordSignInAsync(model.Email, model.Password, isPersistent : true, shouldLockout : false); if (result == SignInStatus.Success) { return(RedirectToAction("Index", "Admin")); } result = await EmployeeSignInManager.PasswordSignInAsync(model.Email, model.Password, isPersistent : true, shouldLockout : false); if (result == SignInStatus.Success) { return(RedirectToAction("Index", "Employee")); } ModelState.AddModelError("", "Invalid login attempt."); return(View(model)); }
public async Task <ActionResult> Register(RegisterViewModel model) { if (ModelState.IsValid) { var user = new AdminUser { UserName = model.Email, Email = model.Email, CompanyName = model.CompanyName, IsAdmin = true, SubsciptionStatus = "Free Plan" }; var result = await AdminUserManager.CreateAsync(user, model.Password); if (result.Succeeded) { var company = await _companyRepository.CreateCompanyAsync(model.CompanyName); user.CompanyId = company.CompanyId; await AdminUserManager.UpdateAsync(user); result = await AdminUserManager.AddToRoleAsync(user.Id, "Admin"); } if (result.Succeeded) { await AdminSignInManager.SignInAsync(user, isPersistent : false, rememberBrowser : false); // For more information on how to enable account confirmation and password reset please visit https://go.microsoft.com/fwlink/?LinkID=320771 // Send an email with this link // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id); // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme); // await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>"); return(RedirectToAction("Index", "Admin")); } AddErrors(result); } // If we got this far, something failed, redisplay form return(View(model)); }
/// <summary> /// Constructor method. /// </summary> public ProfileController(AdminUserManager userManager, AdminSignInManager signInManager, IGlobalizationService globalizationService) { _userManager = userManager ?? throw new ArgumentNullException(nameof(userManager), nameof(ProfileController)); _signInManager = signInManager ?? throw new ArgumentNullException(nameof(signInManager), nameof(ProfileController)); _globalizationService = globalizationService ?? throw new ArgumentNullException(nameof(globalizationService), nameof(ProfileController)); }
public AccountController(AdminUserManager userManager, AdminSignInManager signInManager) { UserManager = userManager; SignInManager = signInManager; }
public BaseHomeController(AdminManager adminManager, AdminSignInManager adminSignInManager, EmployeeSignInManager employeeSignInManager) { AdminUserManager = adminManager; AdminSignInManager = adminSignInManager; _employeeSignInManager = employeeSignInManager; }