Email.cshtml.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. // Licensed to the .NET Foundation under one or more agreements.
  2. // The .NET Foundation licenses this file to you under the MIT license.
  3. #nullable disable
  4. using System;
  5. using System.ComponentModel.DataAnnotations;
  6. using System.Text;
  7. using System.Text.Encodings.Web;
  8. using System.Threading.Tasks;
  9. using Microsoft.AspNetCore.Identity;
  10. using Microsoft.AspNetCore.Identity.UI.Services;
  11. using Microsoft.AspNetCore.Mvc;
  12. using Microsoft.AspNetCore.Mvc.RazorPages;
  13. using Microsoft.AspNetCore.WebUtilities;
  14. namespace bitforum.Areas.Identity.Pages.Account.Manage
  15. {
  16. public class EmailModel : PageModel
  17. {
  18. private readonly UserManager<IdentityUser> _userManager;
  19. private readonly SignInManager<IdentityUser> _signInManager;
  20. private readonly IEmailSender _emailSender;
  21. public EmailModel(
  22. UserManager<IdentityUser> userManager,
  23. SignInManager<IdentityUser> signInManager,
  24. IEmailSender emailSender)
  25. {
  26. _userManager = userManager;
  27. _signInManager = signInManager;
  28. _emailSender = emailSender;
  29. }
  30. /// <summary>
  31. /// This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used
  32. /// directly from your code. This API may change or be removed in future releases.
  33. /// </summary>
  34. public string Email { get; set; }
  35. /// <summary>
  36. /// This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used
  37. /// directly from your code. This API may change or be removed in future releases.
  38. /// </summary>
  39. public bool IsEmailConfirmed { get; set; }
  40. /// <summary>
  41. /// This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used
  42. /// directly from your code. This API may change or be removed in future releases.
  43. /// </summary>
  44. [TempData]
  45. public string StatusMessage { get; set; }
  46. /// <summary>
  47. /// This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used
  48. /// directly from your code. This API may change or be removed in future releases.
  49. /// </summary>
  50. [BindProperty]
  51. public InputModel Input { get; set; }
  52. /// <summary>
  53. /// This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used
  54. /// directly from your code. This API may change or be removed in future releases.
  55. /// </summary>
  56. public class InputModel
  57. {
  58. /// <summary>
  59. /// This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used
  60. /// directly from your code. This API may change or be removed in future releases.
  61. /// </summary>
  62. [Required]
  63. [EmailAddress]
  64. [Display(Name = "New email")]
  65. public string NewEmail { get; set; }
  66. }
  67. private async Task LoadAsync(IdentityUser user)
  68. {
  69. var email = await _userManager.GetEmailAsync(user);
  70. Email = email;
  71. Input = new InputModel
  72. {
  73. NewEmail = email,
  74. };
  75. IsEmailConfirmed = await _userManager.IsEmailConfirmedAsync(user);
  76. }
  77. public async Task<IActionResult> OnGetAsync()
  78. {
  79. var user = await _userManager.GetUserAsync(User);
  80. if (user == null)
  81. {
  82. return NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.");
  83. }
  84. await LoadAsync(user);
  85. return Page();
  86. }
  87. public async Task<IActionResult> OnPostChangeEmailAsync()
  88. {
  89. var user = await _userManager.GetUserAsync(User);
  90. if (user == null)
  91. {
  92. return NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.");
  93. }
  94. if (!ModelState.IsValid)
  95. {
  96. await LoadAsync(user);
  97. return Page();
  98. }
  99. var email = await _userManager.GetEmailAsync(user);
  100. if (Input.NewEmail != email)
  101. {
  102. var userId = await _userManager.GetUserIdAsync(user);
  103. var code = await _userManager.GenerateChangeEmailTokenAsync(user, Input.NewEmail);
  104. code = WebEncoders.Base64UrlEncode(Encoding.UTF8.GetBytes(code));
  105. var callbackUrl = Url.Page(
  106. "/Account/ConfirmEmailChange",
  107. pageHandler: null,
  108. values: new { area = "Identity", userId = userId, email = Input.NewEmail, code = code },
  109. protocol: Request.Scheme);
  110. await _emailSender.SendEmailAsync(
  111. Input.NewEmail,
  112. "Confirm your email",
  113. $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>.");
  114. StatusMessage = "Confirmation link to change email sent. Please check your email.";
  115. return RedirectToPage();
  116. }
  117. StatusMessage = "Your email is unchanged.";
  118. return RedirectToPage();
  119. }
  120. public async Task<IActionResult> OnPostSendVerificationEmailAsync()
  121. {
  122. var user = await _userManager.GetUserAsync(User);
  123. if (user == null)
  124. {
  125. return NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.");
  126. }
  127. if (!ModelState.IsValid)
  128. {
  129. await LoadAsync(user);
  130. return Page();
  131. }
  132. var userId = await _userManager.GetUserIdAsync(user);
  133. var email = await _userManager.GetEmailAsync(user);
  134. var code = await _userManager.GenerateEmailConfirmationTokenAsync(user);
  135. code = WebEncoders.Base64UrlEncode(Encoding.UTF8.GetBytes(code));
  136. var callbackUrl = Url.Page(
  137. "/Account/ConfirmEmail",
  138. pageHandler: null,
  139. values: new { area = "Identity", userId = userId, code = code },
  140. protocol: Request.Scheme);
  141. await _emailSender.SendEmailAsync(
  142. email,
  143. "Confirm your email",
  144. $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>.");
  145. StatusMessage = "Verification email sent. Please check your email.";
  146. return RedirectToPage();
  147. }
  148. }
  149. }