commentaire endpoint

This commit is contained in:
2025-11-05 22:38:55 +01:00
parent 4c0e7df9de
commit 3c32baac57
45 changed files with 475 additions and 479 deletions

View File

@@ -7,17 +7,17 @@ using PyroFetes.Models;
namespace PyroFetes.Endpoints.Product;
public class CreateProductEndpoint(PyroFetesDbContext db)
: Endpoint<CreateProductDto, GetProductDto>
: Endpoint<CreateProductDto, GetProductDto> //Instanciation d'une connexion à la bdd dans un endpoint, utilise l'élément de requête CreateProductDto et l'élement de réponse GetProductDto
{
public override void Configure()
public override void Configure() //Configuration de l'endpoint
{
Post("/api/products");
AllowAnonymous();
Post("/api/products"); //Créer un produit
AllowAnonymous(); //Autorise l'accès sans authentification
}
public override async Task HandleAsync(CreateProductDto req, CancellationToken ct)
{
var product = new Models.Product
var product = new Models.Product //Création d'un nom, référence, durée, calibre, numéro d'aprovisionnement, poids, nec, image, lien, liaison de la catégorie du produit et de la classification rentré par l'utilisateur
{
Reference = req.References.ToString(),
Name = req.Name!,
@@ -32,8 +32,8 @@ public class CreateProductEndpoint(PyroFetesDbContext db)
ClassificationId = req.ClassificationId
};
db.Products.Add(product);
await db.SaveChangesAsync(ct);
db.Products.Add(product); //Ajout du produit à la bdd
await db.SaveChangesAsync(ct); //Sauvegarde du produit dans la bdd
// Ajout des fournisseurs liés
if (req.Suppliers is not null && req.Suppliers.Any())
@@ -46,9 +46,9 @@ public class CreateProductEndpoint(PyroFetesDbContext db)
SupplierId = s.SupplierId,
SellingPrice = s.SellingPrice
};
db.Prices.Add(price);
db.Prices.Add(price); //Ajout du prix à la bdd
}
await db.SaveChangesAsync(ct);
await db.SaveChangesAsync(ct); //Sauvegarde du produit dans la bdd
}
// Ajout des entrepôts liés
@@ -66,9 +66,9 @@ public class CreateProductEndpoint(PyroFetesDbContext db)
WarehouseId = w.WarehouseId,
Quantity = w.Quantity
};
db.WarehouseProducts.Add(warehouseProduct);
db.WarehouseProducts.Add(warehouseProduct); //Ajout du produit de l'entrepot à la bdd
}
await db.SaveChangesAsync(ct);
await db.SaveChangesAsync(ct); //Sauvegarde du produit de l'entrepot dans la bdd
}
// Construction de la réponse
@@ -100,6 +100,6 @@ public class CreateProductEndpoint(PyroFetesDbContext db)
}).ToList() ?? new()
};
await Send.OkAsync(response, ct);
await Send.OkAsync(response, ct); //Réponse au client
}
}

View File

@@ -6,28 +6,28 @@ namespace PyroFetes.Endpoints.Product;
public class DeleteProductRequest
{
public int Id { get; set; }
public int Id { get; set; } //Création d'un Id
}
public class DeleteProductEndpoint(PyroFetesDbContext db) : Endpoint<DeleteProductRequest>
{
public override void Configure()
{
Delete("/api/products/{@id}", x => new { x.Id });
AllowAnonymous();
Delete("/api/products/{@id}", x => new { x.Id }); //endpoint qui supprime un produit grâce à son id
AllowAnonymous(); //Autorise l'accès sans authentification
}
public override async Task HandleAsync(DeleteProductRequest req, CancellationToken ct)
{
// Récupérer le produit
var productToDelete = await db.Products
var productToDelete = await db.Products
.SingleOrDefaultAsync(p => p.Id == req.Id, ct);
if (productToDelete is null)
{
Console.WriteLine($"Aucun produit avec l'ID {req.Id} trouvé.");
await Send.NotFoundAsync(ct);
return;
await Send.NotFoundAsync(ct); //Renvoie une erreur 404
return; //Arrêt de la méthode
}
// Supprimer les liaisons Price
@@ -54,6 +54,6 @@ public class DeleteProductEndpoint(PyroFetesDbContext db) : Endpoint<DeleteProdu
await db.SaveChangesAsync(ct);
Console.WriteLine($"Produit {req.Id}, ses prix et ses entrepôts liés ont été supprimés avec succès.");
await Send.NoContentAsync(ct);
await Send.NoContentAsync(ct); //Renvoie une réponse réussite 204
}
}