blob: d06e850cf1fe5393a79fe964299a6e8d39fa5cd2 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
namespace IOL.BookmarkThing.Server.Api.Internal.Account;
public class UpdatePasswordRoute : RouteBaseInternalSync.WithRequest<UpdatePasswordRequest>.WithActionResult
{
private readonly AppDbContext _context;
public UpdatePasswordRoute(AppDbContext context) {
_context = context;
}
[ApiVersionNeutral]
[ApiExplorerSettings(IgnoreApi = true)]
[HttpPost("~/v{version:apiVersion}/account/update-password")]
public override ActionResult Handle(UpdatePasswordRequest payload) {
if (payload.NewPassword.IsNullOrWhiteSpace()) {
return BadRequest(new ErrorResult("Invalid request",
"The new password field is required"));
}
if (payload.NewPassword.Length < 6) {
return BadRequest(new ErrorResult("Invalid request",
"The new password must contain atleast 6 characters"));
}
var user = _context.Users.SingleOrDefault(c => c.Id == LoggedInUser.Id);
if (user == default) {
HttpContext.SignOutAsync();
return StatusCode(403);
}
user.HashAndSetPassword(payload.NewPassword);
_context.SaveChanges();
return Ok();
}
}
|