1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- using System;
- using System.Collections.Generic;
- using System.ComponentModel.DataAnnotations;
- using System.Text.Encodings.Web;
- using System.Text;
- using System.Threading.Tasks;
- using Microsoft.AspNetCore.Authorization;
- using Microsoft.AspNetCore.Identity;
- using Microsoft.AspNetCore.Identity.UI.Services;
- using Microsoft.AspNetCore.Mvc;
- using Microsoft.AspNetCore.Mvc.RazorPages;
- using Microsoft.AspNetCore.WebUtilities;
- namespace HyperCube.Areas.Identity.Pages.Account
- {
- [AllowAnonymous]
- public class ForgotPasswordModel : PageModel
- {
- private readonly UserManager<IdentityUser> _userManager;
- public ForgotPasswordModel(UserManager<IdentityUser> userManager)
- {
- _userManager = userManager;
- }
- [BindProperty]
- public InputModel Input { get; set; }
- public class InputModel
- {
- [Required]
- [EmailAddress]
- public string Email { get; set; }
- }
- public async Task<IActionResult> OnPostAsync()
- {
- if (ModelState.IsValid)
- {
- var user = await _userManager.FindByEmailAsync(Input.Email);
- if (user == null || !(await _userManager.IsEmailConfirmedAsync(user)))
- {
- // Don't reveal that the user does not exist or is not confirmed
- return RedirectToPage("./ForgotPasswordConfirmation");
- }
- var code = await _userManager.GeneratePasswordResetTokenAsync(user);
- code = WebEncoders.Base64UrlEncode(Encoding.UTF8.GetBytes(code));
- var callbackUrl = Url.Page(
- "/Account/ResetPassword",
- pageHandler: null,
- values: new { area = "Identity", code, Input.Email },
- protocol: Request.Scheme);
- EmailSender emailSender = new();
- await emailSender.SendEmailAsync(Input.Email, "Сброс пароля",
- $"Если вы забыли пароль от своей учетной записи, можно сбросить его по <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>ссылке</a>.");
- return RedirectToPage("./ForgotPasswordConfirmation");
- }
- return Page();
- }
- }
- }
|