MAJ Mathilde

This commit is contained in:
2025-10-09 15:16:08 +02:00
parent f155d03559
commit d1fa3aca68
24 changed files with 628 additions and 211 deletions

View File

@@ -1,6 +1,7 @@
using API.DTO.Warehouse.Response;
using FastEndpoints;
using Microsoft.EntityFrameworkCore;
using PyroFetes.Models;
namespace PyroFetes.Endpoints.Warehouse;
@@ -9,28 +10,32 @@ public class GetWarehouseRequest
public int Id { get; set; }
}
public class GetWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetWarehouseRequest, GetWarehouseDto>
public class GetWarehouseEndpoint(PyroFetesDbContext db)
: Endpoint<GetWarehouseRequest, GetWarehouseDto>
{
public override void Configure()
{
Get("/api/warehouses/{@id}", x => new { x.Id });
// Pas de "@id" ici, juste {id}
Get("/api/warehouses/{id}", x => new { x.Id });
AllowAnonymous();
}
public override async Task HandleAsync(GetWarehouseRequest req, CancellationToken ct)
{
Models.Warehouse? warehouse = await pyrofetesdbcontext
.Warehouses
// 🔹 Inclut les produits associés à cet entrepôt
var warehouse = await db.Warehouses
.Include(w => w.WarehouseProducts)
.ThenInclude(wp => wp.Product)
.SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct);
if (warehouse == null)
{
Console.WriteLine($"Aucun entrepôt avec l'ID {req.Id} trouvé.");
Console.WriteLine($" Aucun entrepôt avec l'ID {req.Id} trouvé.");
await Send.NotFoundAsync(ct);
return;
}
GetWarehouseDto responseDto = new()
var response = new GetWarehouseDto
{
Id = warehouse.Id,
Name = warehouse.Name!,
@@ -39,9 +44,15 @@ public class GetWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpo
MinWeight = warehouse.MinWeight,
Adress = warehouse.Address!,
ZipCode = warehouse.ZipCode,
City = warehouse.City!
City = warehouse.City!,
Products = warehouse.WarehouseProducts.Select(wp => new WarehouseProductDto
{
ProductId = wp.ProductId,
ProductName = wp.Product?.Name,
Quantity = wp.Quantity
}).ToList()
};
await Send.OkAsync(responseDto, ct);
await Send.OkAsync(response, ct);
}
}