aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Endpoints/Internal/PasswordResetRequests/FulfillResetRequestRoute.cs
blob: 6f71b2f9e3827f927a56d78d41d5f91268cbe4bd (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
namespace IOL.GreatOffice.Api.Endpoints.Internal.PasswordResetRequests;

public class FulfillResetRequestRoute : RouteBaseAsync.WithRequest<FulfillResetRequestPayload>.WithActionResult
{
    private readonly PasswordResetService _passwordResetService;

    public FulfillResetRequestRoute(PasswordResetService passwordResetService) {
        _passwordResetService = passwordResetService;
    }

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

            throw;
        }
    }
}