using API.DTO.Effect.Request; using API.DTO.Effect.Response; using FastEndpoints; using Microsoft.EntityFrameworkCore; namespace PyroFetes.Endpoints.Effect; public class UpdateEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint { public override void Configure() //Configuration de l'endpoint { Put("Api/effects/{@id}", x => new { x.Id }); //Création d'un endpoint qui modifie un effet grâce à son id AllowAnonymous(); //Ignorer les requêtes non authentifiées } public override async Task HandleAsync(UpdateEffectDto req, CancellationToken ct) { Models.Effect? effectToEdit = await pyrofetesdbcontext //Récupère un effet dans la bdd et le stocke dans effectToEdit .Effects //Recherche l'effet dans la table Effects .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); //Recherche un effet dont l'id correspond à req.Id if (effectToEdit == null) //Si l'effet n'est pas trouvé { Console.WriteLine($"Aucun effet avec l'id {req.Id} trouvé."); //Afficher qu'aucun effet avec l'id ... n'a été trouvé await Send.NotFoundAsync(ct); //Renvoie une erreur 404 return; //Arrêt de la méthode } effectToEdit.Label = req.Label; //Modification du label de l'effet await pyrofetesdbcontext.SaveChangesAsync(ct); //Sauvegarde les changements effectués dans la base de données GetEffectDto responseDto = new() //Construire l'objet de réponse pour retourner l'id et le label de l'effet modifié { Id = req.Id, //Inclut l'id dans la réponse Label = req.Label, //Inclut le label dans la réponse }; await Send.OkAsync(responseDto, ct); //Envoie une réponse 200 OK avec l'objet de réponse } }