summaryrefslogtreecommitdiffstats
path: root/server/src/Endpoints/Internal/PasswordResetRequests/FulfillResetRequestRoute.cs
blob: e33a4fbec72d693fadf61dc52918582ea45ab5dd (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
namespace IOL.GreatOffice.Api.Endpoints.Internal.PasswordResetRequests;

/// <inheritdoc />
public class FulfillResetRequestRoute : RouteBaseAsync.WithRequest<FulfillResetRequestPayload>.WithActionResult
{
	private readonly ForgotPasswordService _forgotPasswordService;

	/// <inheritdoc />
	public FulfillResetRequestRoute(ForgotPasswordService forgotPasswordService) {
		_forgotPasswordService = forgotPasswordService;
	}

	/// <summary>
	/// Fulfill a password reset request.
	/// </summary>
	/// <param name="request"></param>
	/// <param name="cancellationToken"></param>
	/// <returns></returns>
	[AllowAnonymous]
	[HttpPost("~/_/forgot-password-requests/fulfill")]
	public override async Task<ActionResult> HandleAsync(FulfillResetRequestPayload request, CancellationToken cancellationToken = default) {
		try {
			var fulfilled = await _forgotPasswordService.FullFillRequestAsync(request.Id, request.NewPassword, cancellationToken);
			return Ok(fulfilled);
		} catch (Exception e) {
			if (e is ForgotPasswordRequestNotFoundException or UserNotFoundException) {
				return NotFound();
			}

			throw;
		}
	}
}