summaryrefslogtreecommitdiffstats
path: root/src/server/Api/Internal/Account/UpdatePasswordRoute.cs
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();
	}
}