using Hutopy.Infrastructure.Security; using Hutopy.Modules.Identity.Data; namespace Hutopy.Modules.Identity.Handlers; [PublicAPI] public record ChangePhoneRequest( string? PhoneNumber); [PublicAPI] public class ChangePhoneHandler( UserManager userManager) : Endpoint { public override void Configure() { Post("/api/users/phone"); Options(o => o.WithTags("Users")); } public override async Task HandleAsync( ChangePhoneRequest request, CancellationToken ct) { var user = await userManager.FindByIdAsync(HttpContext.User.GetUserId().ToString()); if (user is null) { await SendNotFoundAsync(ct); return; } user.PhoneNumber = request.PhoneNumber; // TODO: check to see if identity resets the `phone confirmed` flag - @jonathan var result = await userManager.UpdateAsync(user); if (result.Succeeded) await SendOkAsync(ct); else await SendUnauthorizedAsync(ct); } }