public async Task <IActionResult> ChangePasswordUser([FromBody] ChangePasswordDto changePasswordDto) { string userId = User.FindFirstValue(ClaimTypes.NameIdentifier); var user = await _userManager.FindByIdAsync(userId); var result = await _userManager.ChangePasswordAsync(user, changePasswordDto.OldPassword, changePasswordDto.NewPassword); if (!result.Succeeded) { throw new InvalidDataException(ErrorCode.InvalidUser, "Wrong OldPassword"); } return(Ok()); }
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)); }