forked from sanchezvem/PyroFetes
17:17 09/10
This commit is contained in:
@@ -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);
|
||||
}
|
||||
}
|
@@ -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()
|
||||
{
|
||||
// L’annotation 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 l’entrepô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);
|
||||
}
|
||||
}
|
@@ -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);
|
||||
}
|
||||
}
|
@@ -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()
|
||||
{
|
||||
// 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);
|
||||
}
|
||||
}
|
@@ -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()
|
||||
{
|
||||
// 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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user