public async Task<ActionResult> ChangePassword(ChangePasswordViewModel model) { if (!ModelState.IsValid) { return View(model); } var result = await UserManager.ChangePasswordAsync(User.Identity.GetUserId(), model.OldPassword, model.NewPassword); if (result.Succeeded) { var user = await UserManager.FindByIdAsync(User.Identity.GetUserId()); if (user != null) { await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false); } return RedirectToAction("Index", new { Message = ManageMessageId.ChangePasswordSuccess }); } AddErrors(result); return View(model); }
public async Task<IActionResult> ChangePassword(ChangePasswordViewModel model) { if (!ModelState.IsValid) { return View(model); } var user = await GetCurrentUserAsync(); if (user != null) { var result = await _userManager.ChangePasswordAsync(user, model.OldPassword, model.NewPassword); if (result.Succeeded) { await _signInManager.SignInAsync(user, isPersistent: false); return RedirectToAction(nameof(Index), new { Message = ManageMessageId.ChangePasswordSuccess }); } AddErrors(result); return View(model); } return RedirectToAction(nameof(Index), new { Message = ManageMessageId.Error }); }
//[ValidateAntiForgeryToken] public async Task<IActionResult> ChangePassword(ChangePasswordViewModel model) { if (ModelState.IsValid) { var result = await _userManager.ChangePasswordAsync(await GetCurrentUserAsync(), model.OldPassword, model.NewPassword); if (result.Succeeded) { var user = await GetCurrentUserAsync(); user.ChangedPassword = true; var updateUserResult = await _userManager.UpdateAsync(user); if (result.Succeeded) { return Json("OK"); } else { return ErrorMessage.BadRequestJsonResult(updateUserResult.Errors); } } else { return ErrorMessage.BadRequestJsonResult(result.Errors); } } return ErrorMessage.BadRequestJsonResult(ModelState.Values.SelectMany(x => x.Errors)); }
public async Task<ActionResult> ChangePassword(ChangePasswordViewModel model) { if (!ModelState.IsValid) { return View(model); } var user = userRepository.GetByName(HttpContext.User.Identity.Name); if(passwordHasher.VerifyHashedPassword(user.PasswordHash, model.OldPassword)!=PasswordVerificationResult.Failed) { user.PasswordHash = passwordHasher.HashPassword(model.NewPassword); userRepository.SaveOrUpdate(user); FormsAuthentication.SetAuthCookie(user.Name, true); return RedirectToAction("Index", new { Message = ManageMessageId.ChangePasswordSuccess }); } string tekst=""; if (model.ConfirmPassword != model.NewPassword) tekst = "Passwords don't match. "; string[] errors = new string[1]; errors[0] = tekst+"Old password doesn't match"; AddErrors(new IdentityResult(errors)); return View(model); }