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 _userManager; public ForgotPasswordModel(UserManager userManager) { _userManager = userManager; } [BindProperty] public InputModel Input { get; set; } public class InputModel { [Required] [EmailAddress] public string Email { get; set; } } public async Task 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, "Сброс пароля", $"Если вы забыли пароль от своей учетной записи, можно сбросить его по ссылке."); return RedirectToPage("./ForgotPasswordConfirmation"); } return Page(); } } }