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,10 +1,12 @@
using API.DTO.Warehouse.Request;
using API.DTO.Warehouse.Response;
using FastEndpoints;
using PyroFetes.Models;
namespace PyroFetes.Endpoints.Warehouse;
public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateWarehouseDto, GetWarehouseDto>
public class CreateWarehouseEndpoint(PyroFetesDbContext db)
: Endpoint<CreateWarehouseDto, GetWarehouseDto>
{
public override void Configure()
{
@@ -14,7 +16,7 @@ public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
public override async Task HandleAsync(CreateWarehouseDto req, CancellationToken ct)
{
Models.Warehouse warehouse = new()
var warehouse = new Models.Warehouse
{
Name = req.Name,
MaxWeight = req.MaxWeight,
@@ -24,13 +26,27 @@ public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
ZipCode = req.ZipCode,
City = req.City
};
pyrofetesdbcontext.Warehouses.Add(warehouse);
await pyrofetesdbcontext.SaveChangesAsync(ct);
Console.WriteLine("Entrepôt créé avec succès !");
GetWarehouseDto responseDto = new()
db.Warehouses.Add(warehouse);
await db.SaveChangesAsync(ct);
// 🔹 Ajout des produits liés à cet entrepôt
if (req.Products is not null && req.Products.Any())
{
foreach (var p in req.Products)
{
var warehouseProduct = new WarehouseProduct
{
WarehouseId = warehouse.Id,
ProductId = p.ProductId,
Quantity = p.Quantity
};
db.WarehouseProducts.Add(warehouseProduct);
}
await db.SaveChangesAsync(ct);
}
var response = new GetWarehouseDto
{
Id = warehouse.Id,
Name = warehouse.Name,
@@ -42,6 +58,6 @@ public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
City = warehouse.City
};
await Send.OkAsync(responseDto, ct);
await Send.OkAsync(response, ct);
}
}

View File

@@ -1,5 +1,6 @@
using FastEndpoints;
using Microsoft.EntityFrameworkCore;
using PyroFetes.Models;
namespace PyroFetes.Endpoints.Warehouse;
@@ -8,18 +9,20 @@ public class DeleteWarehouseRequest
public int Id { get; set; }
}
public class DeleteWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteWarehouseRequest>
public class DeleteWarehouseEndpoint(PyroFetesDbContext db) : Endpoint<DeleteWarehouseRequest>
{
public override void Configure()
{
Delete("/api/warehouse/{@id}", x => new { x.Id });
// Lannotation correcte du paramètre est {id}, pas {@id}
Delete("/api/warehouse/{id}", x => new { x.Id });
AllowAnonymous();
}
public override async Task HandleAsync(DeleteWarehouseRequest req, CancellationToken ct)
{
Models.Warehouse? warehouseToDelete = await pyrofetesdbcontext
.Warehouses
// On charge aussi les WarehouseProducts liés pour les supprimer proprement
var warehouseToDelete = await db.Warehouses
.Include(w => w.WarehouseProducts)
.SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct);
if (warehouseToDelete == null)
@@ -29,9 +32,21 @@ public class DeleteWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
return;
}
pyrofetesdbcontext.Warehouses.Remove(warehouseToDelete);
await pyrofetesdbcontext.SaveChangesAsync(ct);
// 🔹 Suppression des relations WarehouseProduct avant l'entrepôt
var relatedWarehouseProducts = await db.WarehouseProducts
.Where(wp => wp.WarehouseId == req.Id)
.ToListAsync(ct);
if (relatedWarehouseProducts.Any())
{
db.WarehouseProducts.RemoveRange(relatedWarehouseProducts);
}
// 🔹 Suppression de lentrepôt
db.Warehouses.Remove(warehouseToDelete);
await db.SaveChangesAsync(ct);
Console.WriteLine($"Entrepôt {warehouseToDelete.Name} (ID {req.Id}) supprimé avec succès.");
await Send.NoContentAsync(ct);
}
}

View File

@@ -1,10 +1,13 @@
using API.DTO.Warehouse.Response;
using API.DTO.Warehouse.Request;
using FastEndpoints;
using Microsoft.EntityFrameworkCore;
using PyroFetes.Models;
namespace PyroFetes.Endpoints.Warehouse;
public class GetAllWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetWarehouseDto>>
public class GetAllWarehouseEndpoint(PyroFetesDbContext db)
: EndpointWithoutRequest<List<GetWarehouseDto>>
{
public override void Configure()
{
@@ -14,20 +17,30 @@ public class GetAllWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
public override async Task HandleAsync(CancellationToken ct)
{
List<GetWarehouseDto> responseDto = await pyrofetesdbcontext.Warehouses
.Select(w => new GetWarehouseDto
{
Id = w.Id,
Name = w.Name,
MaxWeight = w.MaxWeight,
Current = w.Current,
MinWeight = w.MinWeight,
Adress = w.Address,
ZipCode = w.ZipCode,
City = w.City
})
// 🔹 On inclut les relations avec WarehouseProducts et Product
var warehouses = await db.Warehouses
.Include(w => w.WarehouseProducts)
.ThenInclude(wp => wp.Product)
.ToListAsync(ct);
await Send.OkAsync(responseDto, ct);
var response = warehouses.Select(w => new GetWarehouseDto
{
Id = w.Id,
Name = w.Name,
MaxWeight = w.MaxWeight,
Current = w.Current,
MinWeight = w.MinWeight,
Adress = w.Address,
ZipCode = w.ZipCode,
City = w.City,
Products = w.WarehouseProducts.Select(wp => new WarehouseProductDto
{
ProductId = wp.ProductId,
ProductName = wp.Product?.Name,
Quantity = wp.Quantity
}).ToList()
}).ToList();
await Send.OkAsync(response, ct);
}
}

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);
}
}

View File

@@ -2,21 +2,25 @@
using API.DTO.Warehouse.Response;
using FastEndpoints;
using Microsoft.EntityFrameworkCore;
using PyroFetes.Models;
namespace PyroFetes.Endpoints.Warehouse;
public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<UpdateWarehouseDto, GetWarehouseDto>
public class UpdateWarehouseEndpoint(PyroFetesDbContext db)
: Endpoint<UpdateWarehouseDto, GetWarehouseDto>
{
public override void Configure()
{
Put("/api/warehouses/{@id}", x => new { x.Id });
// Utilise {id} plutôt que {@id}
Put("/api/warehouses/{id}", x => new { x.Id });
AllowAnonymous();
}
public override async Task HandleAsync(UpdateWarehouseDto req, CancellationToken ct)
{
Models.Warehouse? warehouseToEdit = await pyrofetesdbcontext
.Warehouses
// 🔹 On inclut les produits existants pour pouvoir les modifier
var warehouseToEdit = await db.Warehouses
.Include(w => w.WarehouseProducts)
.SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct);
if (warehouseToEdit == null)
@@ -26,7 +30,7 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
return;
}
// Mise à jour des champs
// 🔹 Mise à jour des champs de base
warehouseToEdit.Name = req.Name;
warehouseToEdit.MaxWeight = req.MaxWeight;
warehouseToEdit.Current = req.Current;
@@ -35,9 +39,30 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
warehouseToEdit.ZipCode = req.ZipCode;
warehouseToEdit.City = req.City;
await pyrofetesdbcontext.SaveChangesAsync(ct);
// 🔹 Gestion des produits associés
if (req.Products is not null)
{
// On supprime les anciens liens pour recréer proprement
var existingLinks = warehouseToEdit.WarehouseProducts.ToList();
if (existingLinks.Any())
db.WarehouseProducts.RemoveRange(existingLinks);
GetWarehouseDto responseDto = new()
foreach (var p in req.Products)
{
var newLink = new WarehouseProduct
{
WarehouseId = warehouseToEdit.Id,
ProductId = p.ProductId,
Quantity = p.Quantity
};
db.WarehouseProducts.Add(newLink);
}
}
await db.SaveChangesAsync(ct);
// 🔹 On renvoie la version mise à jour
var response = new GetWarehouseDto
{
Id = warehouseToEdit.Id,
Name = warehouseToEdit.Name,
@@ -46,9 +71,16 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En
MinWeight = warehouseToEdit.MinWeight,
Adress = warehouseToEdit.Address,
ZipCode = warehouseToEdit.ZipCode,
City = warehouseToEdit.City
City = warehouseToEdit.City,
Products = warehouseToEdit.WarehouseProducts.Select(wp => new WarehouseProductDto
{
ProductId = wp.ProductId,
ProductName = wp.Product?.Name,
Quantity = wp.Quantity
}).ToList()
};
await Send.OkAsync(responseDto, ct);
Console.WriteLine($"Entrepôt {warehouseToEdit.Name} mis à jour avec succès.");
await Send.OkAsync(response, ct);
}
}
}