forked from sanchezvem/PyroFetes
AJout des DTO et endpoint sur le nouveau git
This commit is contained in:
47
PyroFetes/Endpoints/Warehouse/CreateWarehouseEndpoint.cs
Normal file
47
PyroFetes/Endpoints/Warehouse/CreateWarehouseEndpoint.cs
Normal file
@@ -0,0 +1,47 @@
|
||||
using API.DTO.Warehouse.Request;
|
||||
using API.DTO.Warehouse.Response;
|
||||
using FastEndpoints;
|
||||
|
||||
namespace PyroFetes.Endpoints.Warehouse;
|
||||
|
||||
public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateWarehouseDto, GetWarehouseDto>
|
||||
{
|
||||
public override void Configure()
|
||||
{
|
||||
Post("/api/warehouse");
|
||||
AllowAnonymous();
|
||||
}
|
||||
|
||||
public override async Task HandleAsync(CreateWarehouseDto req, CancellationToken ct)
|
||||
{
|
||||
Models.Warehouse warehouse = new()
|
||||
{
|
||||
Name = req.Name,
|
||||
MaxWeight = req.MaxWeight,
|
||||
Current = req.Current,
|
||||
MinWeight = req.MinWeight,
|
||||
Address = req.Adress,
|
||||
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()
|
||||
{
|
||||
Id = warehouse.Id,
|
||||
Name = warehouse.Name,
|
||||
MaxWeight = warehouse.MaxWeight,
|
||||
Current = warehouse.Current,
|
||||
MinWeight = warehouse.MinWeight,
|
||||
Adress = warehouse.Address,
|
||||
ZipCode = warehouse.ZipCode,
|
||||
City = warehouse.City
|
||||
};
|
||||
|
||||
await Send.OkAsync(responseDto, ct);
|
||||
}
|
||||
}
|
37
PyroFetes/Endpoints/Warehouse/DeleteWarehouseEndpoint.cs
Normal file
37
PyroFetes/Endpoints/Warehouse/DeleteWarehouseEndpoint.cs
Normal file
@@ -0,0 +1,37 @@
|
||||
using FastEndpoints;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace PyroFetes.Endpoints.Warehouse;
|
||||
|
||||
public class DeleteWarehouseRequest
|
||||
{
|
||||
public int Id { get; set; }
|
||||
}
|
||||
|
||||
public class DeleteWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteWarehouseRequest>
|
||||
{
|
||||
public override void Configure()
|
||||
{
|
||||
Delete("/api/warehouse/{@id}", x => new { x.Id });
|
||||
AllowAnonymous();
|
||||
}
|
||||
|
||||
public override async Task HandleAsync(DeleteWarehouseRequest req, CancellationToken ct)
|
||||
{
|
||||
Models.Warehouse? warehouseToDelete = await pyrofetesdbcontext
|
||||
.Warehouses
|
||||
.SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct);
|
||||
|
||||
if (warehouseToDelete == null)
|
||||
{
|
||||
Console.WriteLine($"Aucun entrepôt avec l'ID {req.Id} trouvé.");
|
||||
await Send.NotFoundAsync(ct);
|
||||
return;
|
||||
}
|
||||
|
||||
pyrofetesdbcontext.Warehouses.Remove(warehouseToDelete);
|
||||
await pyrofetesdbcontext.SaveChangesAsync(ct);
|
||||
|
||||
await Send.NoContentAsync(ct);
|
||||
}
|
||||
}
|
33
PyroFetes/Endpoints/Warehouse/GetAllWarehouseEndpoint.cs
Normal file
33
PyroFetes/Endpoints/Warehouse/GetAllWarehouseEndpoint.cs
Normal file
@@ -0,0 +1,33 @@
|
||||
using API.DTO.Warehouse.Response;
|
||||
using FastEndpoints;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace PyroFetes.Endpoints.Warehouse;
|
||||
|
||||
public class GetAllWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetWarehouseDto>>
|
||||
{
|
||||
public override void Configure()
|
||||
{
|
||||
Get("/api/warehouses");
|
||||
AllowAnonymous();
|
||||
}
|
||||
|
||||
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
|
||||
})
|
||||
.ToListAsync(ct);
|
||||
|
||||
await Send.OkAsync(responseDto, ct);
|
||||
}
|
||||
}
|
47
PyroFetes/Endpoints/Warehouse/GetWarehouseEndpoint.cs
Normal file
47
PyroFetes/Endpoints/Warehouse/GetWarehouseEndpoint.cs
Normal file
@@ -0,0 +1,47 @@
|
||||
using API.DTO.Warehouse.Response;
|
||||
using FastEndpoints;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace PyroFetes.Endpoints.Warehouse;
|
||||
|
||||
public class GetWarehouseRequest
|
||||
{
|
||||
public int Id { get; set; }
|
||||
}
|
||||
|
||||
public class GetWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetWarehouseRequest, GetWarehouseDto>
|
||||
{
|
||||
public override void Configure()
|
||||
{
|
||||
Get("/api/warehouses/{@id}", x => new { x.Id });
|
||||
AllowAnonymous();
|
||||
}
|
||||
|
||||
public override async Task HandleAsync(GetWarehouseRequest req, CancellationToken ct)
|
||||
{
|
||||
Models.Warehouse? warehouse = await pyrofetesdbcontext
|
||||
.Warehouses
|
||||
.SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct);
|
||||
|
||||
if (warehouse == null)
|
||||
{
|
||||
Console.WriteLine($"Aucun entrepôt avec l'ID {req.Id} trouvé.");
|
||||
await Send.NotFoundAsync(ct);
|
||||
return;
|
||||
}
|
||||
|
||||
GetWarehouseDto responseDto = new()
|
||||
{
|
||||
Id = warehouse.Id,
|
||||
Name = warehouse.Name!,
|
||||
MaxWeight = warehouse.MaxWeight,
|
||||
Current = warehouse.Current,
|
||||
MinWeight = warehouse.MinWeight,
|
||||
Adress = warehouse.Address!,
|
||||
ZipCode = warehouse.ZipCode,
|
||||
City = warehouse.City!
|
||||
};
|
||||
|
||||
await Send.OkAsync(responseDto, ct);
|
||||
}
|
||||
}
|
54
PyroFetes/Endpoints/Warehouse/UpdateWarehouseEndpoint.cs
Normal file
54
PyroFetes/Endpoints/Warehouse/UpdateWarehouseEndpoint.cs
Normal file
@@ -0,0 +1,54 @@
|
||||
using API.DTO.Warehouse.Request;
|
||||
using API.DTO.Warehouse.Response;
|
||||
using FastEndpoints;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace PyroFetes.Endpoints.Warehouse;
|
||||
|
||||
public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<UpdateWarehouseDto, GetWarehouseDto>
|
||||
{
|
||||
public override void Configure()
|
||||
{
|
||||
Put("/api/warehouses/{@id}", x => new { x.Id });
|
||||
AllowAnonymous();
|
||||
}
|
||||
|
||||
public override async Task HandleAsync(UpdateWarehouseDto req, CancellationToken ct)
|
||||
{
|
||||
Models.Warehouse? warehouseToEdit = await pyrofetesdbcontext
|
||||
.Warehouses
|
||||
.SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct);
|
||||
|
||||
if (warehouseToEdit == null)
|
||||
{
|
||||
Console.WriteLine($"Aucun entrepôt avec l'ID {req.Id} trouvé.");
|
||||
await Send.NotFoundAsync(ct);
|
||||
return;
|
||||
}
|
||||
|
||||
// Mise à jour des champs
|
||||
warehouseToEdit.Name = req.Name;
|
||||
warehouseToEdit.MaxWeight = req.MaxWeight;
|
||||
warehouseToEdit.Current = req.Current;
|
||||
warehouseToEdit.MinWeight = req.MinWeight;
|
||||
warehouseToEdit.Address = req.Adress;
|
||||
warehouseToEdit.ZipCode = req.ZipCode;
|
||||
warehouseToEdit.City = req.City;
|
||||
|
||||
await pyrofetesdbcontext.SaveChangesAsync(ct);
|
||||
|
||||
GetWarehouseDto responseDto = new()
|
||||
{
|
||||
Id = warehouseToEdit.Id,
|
||||
Name = warehouseToEdit.Name,
|
||||
MaxWeight = warehouseToEdit.MaxWeight,
|
||||
Current = warehouseToEdit.Current,
|
||||
MinWeight = warehouseToEdit.MinWeight,
|
||||
Adress = warehouseToEdit.Address,
|
||||
ZipCode = warehouseToEdit.ZipCode,
|
||||
City = warehouseToEdit.City
|
||||
};
|
||||
|
||||
await Send.OkAsync(responseDto, ct);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user