public async Task <IActionResult> Register(RegisterViewModel model, string returnUrl = null) { ViewData["ReturnUrl"] = returnUrl; if (ModelState.IsValid) { var user = new ApplicationUser { UserName = model.Email, Email = model.Email }; var result = await _userManager.CreateAsync(user, model.Password); if (result.Succeeded) { _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.Email, callbackUrl); await _signInManager.SignInAsync(user, isPersistent : false); _logger.LogInformation("User created a new account with password."); return(RedirectToLocal(returnUrl)); } AddErrors(result); } // If we got this far, something failed, redisplay form return(View(model)); }
public async Task <IActionResult> OnPostSendVerificationEmailAsync() { if (!ModelState.IsValid) { return(Page()); } var user = await _userManager.GetUserAsync(User); if (user == null) { return(NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.")); } var userId = await _userManager.GetUserIdAsync(user); var email = await _userManager.GetEmailAsync(user); var code = await _userManager.GenerateEmailConfirmationTokenAsync(user); var callbackUrl = Url.Page( "/Account/ConfirmEmail", pageHandler: null, values: new { userId = userId, code = code }, protocol: Request.Scheme); //await _emailSender.SendEmailAsync( // email, // "Confirm your email", // $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>."); await _emailSender.SendEmailConfirmationAsync(email, callbackUrl); StatusMessage = "Verification email sent. Please check your email."; return(RedirectToPage()); }
public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl = returnUrl ?? Url.Content("~/"); if (ModelState.IsValid) { var user = new ApplicationUser { UserName = Input.Email, Email = Input.Email, PhoneNumber = Input.PhoneNumber, FirstName = Input.FirstName, LastName = Input.LastName }; var result = await _userManager.CreateAsync(user, Input.Password); if (result.Succeeded) { //[email protected] //ph : 1112223333 //name : Admin Spark if (!await _roleManager.RoleExistsAsync(SD.AdminEndUser)) { await _roleManager.CreateAsync(new IdentityRole(SD.AdminEndUser)); var userAdmin = new ApplicationUser { UserName = "******", Email = "*****@*****.**", PhoneNumber = "1112223333", FirstName = "Admin", LastName = "Spark" }; var resultAdmin = await _userManager.CreateAsync(userAdmin, "Admin123*"); await _userManager.AddToRoleAsync(userAdmin, SD.AdminEndUser); } if (!await _roleManager.RoleExistsAsync(SD.AdminEndUser)) { await _roleManager.CreateAsync(new IdentityRole(SD.AdminEndUser)); } if (!await _roleManager.RoleExistsAsync(SD.CustomerEndUser)) { await _roleManager.CreateAsync(new IdentityRole(SD.CustomerEndUser)); } await _userManager.AddToRoleAsync(user, SD.AdminEndUser); _logger.LogInformation("User created a new account with password."); var code = await _userManager.GenerateEmailConfirmationTokenAsync(user); var callbackUrl = Url.Page( "/Account/ConfirmEmail", pageHandler: null, values: new { userId = user.Id, code = code }, protocol: Request.Scheme); //await _emailSender.SendEmailAsync(Input.Email, "Confirm your email", // $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>."); await _emailSender.SendEmailConfirmationAsync(user.Email, callbackUrl); await _signInManager.SignInAsync(user, isPersistent : false); HttpContext.Session.SetInt32("CartCount", 0);//AGREGADO POSTERIORMENTE(PARA IMPLEMENTAR SHOPPING CART) return(LocalRedirect(returnUrl)); } foreach (var error in result.Errors) { ModelState.AddModelError(string.Empty, error.Description); } } // If we got this far, something failed, redisplay form return(Page()); }