using PyroFetes.DTO.Login.Request; using PyroFetes.DTO.Login.Response; using FastEndpoints; using Microsoft.EntityFrameworkCore; using PasswordGenerator; namespace PyroFetes.Endpoints.Login; public class UpdateLoginEndpoint(PyroFetesDbContext database) : Endpoint { public override void Configure() { Put("/api/logins/{@Id}", x => new {x.Id}); } public override async Task HandleAsync(UpdateLoginDto req, CancellationToken ct) { var login = await database.Logins.SingleOrDefaultAsync(x => x.Id == req.Id, ct); if (login == null) { await Send.NotFoundAsync(ct); return; } string? salt = new Password().IncludeLowercase().IncludeUppercase().IncludeNumeric().LengthRequired(24).Next(); login.Username = req.Username; login.FullName = req.FullName; login.Password = BCrypt.Net.BCrypt.HashPassword(req.Password + salt); login.Salt = salt; await database.SaveChangesAsync(ct); GetLoginDto responseDto = new() { Id = login.Id, Username = login.Username, FullName = login.FullName, Password = login.Password, Salt = login.Salt }; await Send.OkAsync(responseDto, ct); } }