public async Task <IActionResult> RegisterAdmin(RegisterWithUserInfo model, string returnUrl = null) { ViewData["action"] = "RegisterAdmin"; ViewData["ReturnUrl"] = returnUrl; if (ModelState.IsValid) { var result = await CreateUserByRole(model, "Admin"); if (result.Succeeded) { return(RedirectToLocal(returnUrl)); } AddErrors(result); } return(View("Register", model)); }
public async Task <IActionResult> RegisterBusiness(RegisterWithUserInfo model, string returnUrl = null) { //ViewData["action"] = "RegisterAdmin"; ViewData["ReturnUrl"] = returnUrl; if (ModelState.IsValid) { var result = await CreateUserByRole(model, "business"); if (result.Succeeded) { return(RedirectToAction("BusinessLocation", "UserInformation", new { id = model.UserInformation.UserId })); } AddErrors(result); } return(View("Register", model)); }
public async Task <IActionResult> Register(RegisterWithUserInfo model, string returnUrl = null) { ViewData["action"] = "Register"; ViewData["ReturnUrl"] = returnUrl; if (ModelState.IsValid) { var result = await CreateUserByRole(model, "User"); if (result.Succeeded) { return(RedirectToLocal(returnUrl)); } AddErrors(result); } // If we got this far, something failed, redisplay form return(View(model)); }
public async Task <IdentityResult> CreateUserByRole(RegisterWithUserInfo model, string Role) { var user = new ApplicationUser { UserName = model.IdentityRegister.Email, Email = model.IdentityRegister.Email, PhoneNumber = model.IdentityRegister.PhoneNumber }; var result = await _userManager.CreateAsync(user, model.IdentityRegister.Password); if (result.Succeeded) { await _userManager.AddToRoleAsync(user, Role); model.UserInformation.UserId = new Guid(user.Id); _context.UserInformation.Add(model.UserInformation); _context.SaveChanges(); _logger.LogInformation("User created a new account with password."); var code = await _userManager.GenerateEmailConfirmationTokenAsync(user); var callbackUrl = Url.EmailConfirmationLink(user.Id, code, Request.Scheme); await _emailSender.SendEmailConfirmationAsync(model.IdentityRegister.Email, callbackUrl); if (!User.IsInRole("Admin")) { await _signInManager.SignInAsync(user, isPersistent : false); _logger.LogInformation("User created a new account with password."); } } return(result); }