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);
 }
Example #2
0
 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 });
 }
Example #3
0
 //[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));
 }
Example #4
0
 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);
 }