Compare commits

..

35 Commits

Author SHA1 Message Date
418c2b3d16 fix error 2025-12-20 15:39:05 +01:00
Cristiano
3487baad87 Added endpoint to get products under their limit 2025-12-18 14:41:45 +01:00
29e2036965 fix error 2025-12-13 15:34:29 +01:00
be7a3193ab added CreateQuotationEndpoint.cs 2025-12-13 15:08:18 +01:00
0802ec9e33 new migration 2025-12-13 11:39:56 +01:00
35d3e58d86 fix error and add CreatePurchaseOrder.cs 2025-12-13 11:24:01 +01:00
2a42e1010f fix error 2025-12-12 21:57:58 +01:00
2fa74ccba8 added UpdateQuotationDto.cs 2025-12-12 21:18:13 +01:00
65cff130e4 update deliverynote endpoint 2025-12-11 17:46:23 +01:00
e21e2afea4 fix error 2025-12-04 17:11:34 +01:00
17978e7c19 change response in endpoint to generate pdf 2025-12-04 16:38:27 +01:00
6a20676b32 added showcompagnon 2025-12-04 15:06:36 +01:00
e440dcd2b5 added pdf generation for all orders 2025-12-03 17:41:19 +01:00
bee1cfb0e3 added PDF generation for quotation 2025-12-03 17:00:02 +01:00
d709654410 fix error in GetTotalQuantityEndpoint.cs 2025-11-30 16:59:28 +01:00
4a82c51133 fixed errors 2025-11-30 15:43:59 +01:00
8a04adeec3 updated GetSupplierDto.cs 2025-11-30 15:35:08 +01:00
db9219e80f fix error in PatchRealDeliveryDateEndpoint.cs 2025-11-30 14:50:21 +01:00
9e6834754f added DeleteDeliveryNoteEndpoint.cs 2025-11-30 14:23:30 +01:00
efa7a0be6f added DeleteProductEndpoint.cs 2025-11-29 21:58:20 +01:00
2a439ccbb5 added mapper 2025-11-28 09:51:12 +01:00
5c6798a647 fixed errors 2025-11-27 17:24:48 +01:00
Cristiano
50a5f371dd Fixed Database 2025-11-27 14:35:35 +01:00
86c5d6ae7b new migration 2025-11-27 13:41:55 +01:00
1c0432a2c4 updated length of password in User.cs 2025-11-27 13:40:02 +01:00
3e8f36457e fixed errors in database 2025-11-26 20:37:49 +01:00
5d68ee6992 fix length on approval number 2025-11-26 19:43:54 +01:00
Cristiano
d26284d552 Merge branch 'feature/repositories-refactor' into develop 2025-11-20 16:45:55 +01:00
Cristiano
d537051bea Fix Type errors 2025-11-20 16:45:44 +01:00
Cristiano
3ad506f869 Retired /api in all the endpoints 2025-11-20 16:33:56 +01:00
Cristiano
9aac7c39f2 Merge branch 'feature/repositories-refactor' into develop
# Conflicts:
#	PyroFetes/Endpoints/Price/CreatePriceEndpoint.cs
#	PyroFetes/Endpoints/Product/GetAllProductsEndpoint.cs
#	PyroFetes/Endpoints/Product/GetProductEndpoint.cs
#	PyroFetes/Endpoints/PurchaseOrder/GetAllPurchaseOrderEndpoint.cs
#	PyroFetes/Endpoints/PurchaseOrder/GetPurchaseOrderEndpoint.cs
#	PyroFetes/Endpoints/Quotation/GetAllQuotationEndpoint.cs
#	PyroFetes/Endpoints/Quotation/GetQuotationEndpoint.cs
#	PyroFetes/Endpoints/SettingEndpoints/CreateSettingEndpoint.cs
#	PyroFetes/Endpoints/SettingEndpoints/PatchSettingElectronicSignatureEndpoint.cs
#	PyroFetes/Endpoints/SettingEndpoints/PatchSettingLogoEndpoint.cs
#	PyroFetes/Endpoints/Supplier/CreateSupplierEndpoint.cs
#	PyroFetes/Endpoints/Supplier/GetAllSuppliersEndpoint.cs
#	PyroFetes/Endpoints/Supplier/GetSupplierEndpoint.cs
#	PyroFetes/Endpoints/Supplier/PatchSupplierDeleveryDelayEndpoint.cs
#	PyroFetes/Endpoints/User/GetAllUsersEndpoint.cs
#	PyroFetes/Endpoints/User/GetUserEndpoint.cs
2025-11-20 16:16:15 +01:00
Cristiano
b76b668097 Addapted to use cors and optimized connection with the frontend 2025-11-20 16:12:16 +01:00
Cristiano
669938d677 Refactored WarehouseProduct 2025-11-20 16:09:04 +01:00
Cristiano
165c9b9322 Refactored User 2025-11-20 15:38:53 +01:00
27e8fea7f3 added AllowAnonymous(); 2025-11-17 21:20:04 +01:00
117 changed files with 11318 additions and 190 deletions

View File

@@ -0,0 +1,6 @@
namespace PyroFetes.DTO.DeliveryNote.Request;
public class GetDeliveryNotePdfDto
{
public int Id { get; set; }
}

View File

@@ -17,8 +17,8 @@ public class CreatePriceDto
public string? ProductReferences { get; set; } public string? ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -10,7 +10,7 @@ public class GetPriceDto
public string? SupplierEmail { get; set; } public string? SupplierEmail { get; set; }
public string? SupplierPhone { get; set; } public string? SupplierPhone { get; set; }
public string? SupplierAddress { get; set; } public string? SupplierAddress { get; set; }
public int SupplierZipCode { get; set; } public string? SupplierZipCode { get; set; }
public string? SupplierCity { get; set; } public string? SupplierCity { get; set; }
public int SupplierDeliveryDelay { get; set; } public int SupplierDeliveryDelay { get; set; }
@@ -18,8 +18,8 @@ public class GetPriceDto
public string? ProductReferences { get; set; } public string? ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -5,8 +5,8 @@ public class CreateProductDto
public string? References { get; set; } public string? References { get; set; }
public string? Name { get; set; } public string? Name { get; set; }
public decimal Duration {get; set;} public decimal Duration {get; set;}
public decimal Caliber { get; set; } public int Caliber { get; set; }
public int ApprovalNumber { get; set; } public string? ApprovalNumber { get; set; }
public decimal Weight { get; set; } public decimal Weight { get; set; }
public decimal Nec { get; set; } public decimal Nec { get; set; }
public string? Image { get; set; } public string? Image { get; set; }

View File

@@ -6,8 +6,8 @@ public class UpdateProductDto
public string? References { get; set; } public string? References { get; set; }
public string? Name { get; set; } public string? Name { get; set; }
public decimal Duration {get; set;} public decimal Duration {get; set;}
public decimal Caliber { get; set; } public int Caliber { get; set; }
public int ApprovalNumber { get; set; } public string? ApprovalNumber { get; set; }
public decimal Weight { get; set; } public decimal Weight { get; set; }
public decimal Nec { get; set; } public decimal Nec { get; set; }
public string? Image { get; set; } public string? Image { get; set; }

View File

@@ -6,8 +6,8 @@ public class GetProductDto
public string? References { get; set; } public string? References { get; set; }
public string? Name { get; set; } public string? Name { get; set; }
public decimal Duration {get; set;} public decimal Duration {get; set;}
public decimal Caliber { get; set; } public int Caliber { get; set; }
public int ApprovalNumber { get; set; } public string? ApprovalNumber { get; set; }
public decimal Weight { get; set; } public decimal Weight { get; set; }
public decimal Nec { get; set; } public decimal Nec { get; set; }
public string? Image { get; set; } public string? Image { get; set; }

View File

@@ -3,11 +3,11 @@ namespace PyroFetes.DTO.ProductDelivery.Response;
public class GetProductDeliveryDto public class GetProductDeliveryDto
{ {
public int ProductId { get; set; } public int ProductId { get; set; }
public int ProductReference { get; set; } public string? ProductReference { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -0,0 +1,9 @@
using PyroFetes.DTO.PurchaseProduct.Request;
namespace PyroFetes.DTO.PurchaseOrder.Request;
public class CreatePurchaseOrderDto
{
public string? PurchaseConditions { get; set; }
public List<CreatePurchaseOrderProductDto>? Products { get; set; }
}

View File

@@ -0,0 +1,6 @@
namespace PyroFetes.DTO.PurchaseOrder.Request;
public class GetPurchaseOrderPdfDto
{
public int Id { get; set; }
}

View File

@@ -6,5 +6,5 @@ public class GetPurchaseOrderDto
{ {
public int Id { get; set; } public int Id { get; set; }
public string? PurchaseConditions { get; set; } public string? PurchaseConditions { get; set; }
public List<GetPurchaseProductDto>? GetPurchaseProductDto { get; set; } public List<GetPurchaseProductDto>? Products { get; set; }
} }

View File

@@ -0,0 +1,8 @@
namespace PyroFetes.DTO.PurchaseProduct.Request;
// Pour ajouter les produits lors de la création
public class CreatePurchaseOrderProductDto
{
public int ProductId { get; set; }
public int Quantity { get; set; }
}

View File

@@ -7,11 +7,11 @@ public class UpdatePurchaseProductDto
public int Quantity { get; set; } public int Quantity { get; set; }
public int ProductReferences { get; set; } public string? ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -6,8 +6,8 @@ public class GetPurchaseProductDto
public string? ProductReferences { get; set; } public string? ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -0,0 +1,10 @@
using PyroFetes.DTO.QuotationProduct.Request;
namespace PyroFetes.DTO.Quotation.Request;
public class CreateQuotationDto
{
public string? Message { get; set; }
public string? ConditionsSale { get; set; }
public List<CreateProductQuotationDto>? Products { get; set; }
}

View File

@@ -0,0 +1,6 @@
namespace PyroFetes.DTO.Quotation.Request;
public class GetQuotationPdfDto
{
public int Id { get; set; }
}

View File

@@ -0,0 +1,8 @@
namespace PyroFetes.DTO.Quotation.Request;
public class UpdateQuotationDto
{
public int Id { get; set; }
public string? Message { get; set; }
public string? ConditionsSale { get; set; }
}

View File

@@ -7,5 +7,5 @@ public class GetQuotationDto
public int Id { get; set; } public int Id { get; set; }
public string? Message { get; set; } public string? Message { get; set; }
public string? ConditionsSale { get; set; } public string? ConditionsSale { get; set; }
public List<GetQuotationProductDto>? GetQuotationProductDto { get; set; } public List<GetQuotationProductDto>? Products { get; set; }
} }

View File

@@ -0,0 +1,8 @@
namespace PyroFetes.DTO.QuotationProduct.Request;
// Pour création global
public class CreateProductQuotationDto
{
public int ProductId { get; set; }
public int Quantity { get; set; }
}

View File

@@ -12,8 +12,8 @@ public class CreateQuotationProductDto
public int ProductReferences { get; set; } public int ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -13,8 +13,8 @@ public class UpdateQuotationProductDto
public int ProductReferences { get; set; } public int ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -12,8 +12,8 @@ public class GetQuotationProductDto
public string? ProductReferences { get; set; } public string? ProductReferences { get; set; }
public string? ProductName { get; set; } public string? ProductName { get; set; }
public decimal ProductDuration {get; set;} public decimal ProductDuration {get; set;}
public decimal ProductCaliber { get; set; } public int ProductCaliber { get; set; }
public int ProductApprovalNumber { get; set; } public string? ProductApprovalNumber { get; set; }
public decimal ProductWeight { get; set; } public decimal ProductWeight { get; set; }
public decimal ProductNec { get; set; } public decimal ProductNec { get; set; }
public string? ProductImage { get; set; } public string? ProductImage { get; set; }

View File

@@ -1,3 +1,6 @@
using PyroFetes.DTO.Price.Response;
using PyroFetes.DTO.Product.Response;
namespace PyroFetes.DTO.Supplier.Response; namespace PyroFetes.DTO.Supplier.Response;
public class GetSupplierDto public class GetSupplierDto
@@ -10,4 +13,6 @@ public class GetSupplierDto
public string? ZipCode { get; set; } public string? ZipCode { get; set; }
public string? City { get; set; } public string? City { get; set; }
public int DeliveryDelay { get; set; } public int DeliveryDelay { get; set; }
public List<GetProductDto>? Products { get; set; }
public List<GetPriceDto>? Prices { get; set; }
} }

View File

@@ -12,7 +12,7 @@ public class CreateDelivererEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("api/deliverers"); Post("/deliverers");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -13,7 +13,7 @@ public class DeleteDelivererEndpoint(DeliverersRepository deliverersRepository)
{ {
public override void Configure() public override void Configure()
{ {
Delete("api/deliverers/{@id}", x=>new {x.DelivererId}); Delete("/deliverers/{@id}", x=>new {x.DelivererId});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -10,7 +10,7 @@ public class GetAllDelivererEndpoint(DeliverersRepository deliverersRepository)
{ {
public override void Configure() public override void Configure()
{ {
Get("api/deliverers"); Get("/deliverers");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -18,7 +18,7 @@ public class GetDelivererEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("api/deliverers/{@id}", x=>new {x.DelivererId}); Get("/deliverers/{@id}", x=>new {x.DelivererId});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class UpdateDelivererEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Put("api/deliverers/{@id}", x=>new {x.Id}); Put("/deliverers/{@id}", x=>new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -17,7 +17,7 @@ public class CreateDeliveryNoteEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/DeliveryNote"); Post("/deliveryNotes");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,38 @@
using FastEndpoints;
using PyroFetes.Endpoints.Quotations;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.DeliveryNotes;
using PyroFetes.Specifications.Quotations;
namespace PyroFetes.Endpoints.DeliveryNotes;
public class DeleteDeliveryNoteRequest
{
public int Id { get; set; }
}
public class DeleteDeliveryNoteEndpoint(
DeliveryNotesRepository deliveryNotesRepository) : Endpoint<DeleteDeliveryNoteRequest>
{
public override void Configure()
{
Delete("/deliveryNotes/{@Id}", x => new {x.Id});
AllowAnonymous();
}
public override async Task HandleAsync(DeleteDeliveryNoteRequest req, CancellationToken ct)
{
DeliveryNote? deliveryNote = await deliveryNotesRepository.FirstOrDefaultAsync(new GetDeliveryNoteByIdSpec(req.Id), ct);
if (deliveryNote == null)
{
await Send.NotFoundAsync(ct);
return;
}
await deliveryNotesRepository.DeleteAsync(deliveryNote, ct);
await Send.NoContentAsync(ct);
}
}

View File

@@ -8,7 +8,7 @@ public class GetAllDeliveryNoteEndpoint(DeliveryNotesRepository deliveryNotesRep
{ {
public override void Configure() public override void Configure()
{ {
Get("api/deliveryNotes"); Get("/deliveryNotes");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -16,7 +16,7 @@ public class GetDeliveryNoteEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/deliveryNote/{@id}", x=> new {x.DeliveryNoteId}); Get("/deliveryNotes/{@id}", x=> new {x.DeliveryNoteId});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,43 @@
using System.Net.Mime;
using FastEndpoints;
using PyroFetes.DTO.DeliveryNote.Request;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Services.Pdf;
using PyroFetes.Specifications.DeliveryNotes;
using PyroFetes.Specifications.Quotations;
namespace PyroFetes.Endpoints.DeliveryNotes;
public class GetDeliveryNotePdfEndpoint(
DeliveryNotesRepository deliveryNotesRepository,
IDeliveryNotePdfService deliveryNotePdfService)
: Endpoint<GetDeliveryNotePdfDto, byte[]>
{
public override void Configure()
{
Get("/deliveryNotes/{@Id}/pdf", x => new {x.Id});
AllowAnonymous();
Description(b => b.Produces<byte[]>(200, MediaTypeNames.Application.Pdf));
}
public override async Task HandleAsync(GetDeliveryNotePdfDto req, CancellationToken ct)
{
DeliveryNote? deliveryNote = await deliveryNotesRepository
.FirstOrDefaultAsync(new GetDeliveryNoteByIdWithProductsSpec(req.Id), ct);
if (deliveryNote == null)
{
await Send.NotFoundAsync(ct);
return;
}
var bytes = deliveryNotePdfService.Generate(deliveryNote, deliveryNote.ProductDeliveries!);
await Send.BytesAsync(
bytes: bytes,
contentType: "application/pdf",
fileName: $"bon-de-livraison-{deliveryNote.Id}.pdf",
cancellation: ct);
}
}

View File

@@ -15,7 +15,7 @@ public class PatchRealDeliveryDateEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/deliveryNote/{@id}", x=> new {x.Id}); Patch("/deliveryNotes/{@id}", x=> new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }
@@ -30,6 +30,12 @@ public class PatchRealDeliveryDateEndpoint(
return; return;
} }
if (deliveryNoteToPath.RealDeliveryDate != null)
{
await Send.StringAsync("Impossible de modifier la date.", 400);
return;
}
deliveryNoteToPath.RealDeliveryDate = req.RealDeliveryDate; deliveryNoteToPath.RealDeliveryDate = req.RealDeliveryDate;
await deliveryNotesRepository.UpdateAsync(deliveryNoteToPath, ct); await deliveryNotesRepository.UpdateAsync(deliveryNoteToPath, ct);

View File

@@ -0,0 +1,40 @@
using FastEndpoints;
using PyroFetes.DTO.DeliveryNote.Request;
using PyroFetes.DTO.DeliveryNote.Response;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.DeliveryNotes;
namespace PyroFetes.Endpoints.DeliveryNotes;
public class UpdateDeliveryNoteEndpoint(
DeliveryNotesRepository deliveryNotesRepository,
AutoMapper.IMapper mapper) : Endpoint<UpdateDeliveryNoteDto, GetDeliveryNoteDto>
{
public override void Configure()
{
Put("/deliveryNotes/{@Id}", x => new {x.Id});
AllowAnonymous();
}
public override async Task HandleAsync(UpdateDeliveryNoteDto req, CancellationToken ct)
{
DeliveryNote? deliveryNote = await deliveryNotesRepository.FirstOrDefaultAsync(new GetDeliveryNoteByIdSpec(req.Id), ct);
if (deliveryNote == null)
{
await Send.NotFoundAsync(ct);
return;
}
deliveryNote.TrackingNumber = req.TrackingNumber;
deliveryNote.EstimateDeliveryDate = req.EstimateDeliveryDate;
deliveryNote.ExpeditionDate = req.ExpeditionDate;
deliveryNote.RealDeliveryDate = req.RealDeliveryDate;
deliveryNote.DelivererId = req.DelivererId;
await deliveryNotesRepository.UpdateAsync(deliveryNote, ct);
await Send.OkAsync(mapper.Map<GetDeliveryNoteDto>(deliveryNote), ct);
}
}

View File

@@ -17,7 +17,7 @@ public class CreatePriceEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/prices"); Post("/prices");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -16,7 +16,7 @@ public class DeletePriceEndpoint(PricesRepository pricesRepository) : Endpoint<D
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/prices/{@ProductId}/{@SupplierId}", x => new {x.ProductId, x.SupplierId}); Delete("/prices/{@ProductId}/{@SupplierId}", x => new {x.ProductId, x.SupplierId});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -13,7 +13,7 @@ public class PatchPriceEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/prices/{@ProductId}/{@SupplierId}/SellingPrice", x => new { x.ProductId, x.SupplierId }); Patch("/prices/{@ProductId}/{@SupplierId}/SellingPrice", x => new { x.ProductId, x.SupplierId });
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,38 @@
using FastEndpoints;
using PyroFetes.Endpoints.Deliverers;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Deliverers;
using PyroFetes.Specifications.Products;
namespace PyroFetes.Endpoints.Products;
public class DeleteProductsRequest
{
public int ProductId { get; set; }
}
public class DeleteProductEndpoint(ProductsRepository productsRepository) : Endpoint<DeleteProductsRequest>
{
public override void Configure()
{
Delete("/products/{@id}", x=>new {x.ProductId});
AllowAnonymous();
}
public override async Task HandleAsync(DeleteProductsRequest req, CancellationToken ct)
{
Product? product = await productsRepository.FirstOrDefaultAsync(new GetProductByIdSpec(req.ProductId), ct);
if (product == null)
{
await Send.NotFoundAsync(ct);
return;
}
await productsRepository.DeleteAsync(product, ct);
await Send.OkAsync(ct);
}
}

View File

@@ -10,7 +10,7 @@ public class GetAllProductsEndpoint(ProductsRepository productsRepository) : End
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/products"); Get("/products");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,21 @@
using AutoMapper;
using FastEndpoints;
using PyroFetes.DTO.Product.Response;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Products;
namespace PyroFetes.Endpoints.Products;
public class GetAllProductsUnderLimitEndpoint(ProductsRepository productsRepository) : EndpointWithoutRequest<List<GetProductDto>>
{
public override void Configure()
{
Get("/products/underLimit");
AllowAnonymous();
}
public override async Task HandleAsync(CancellationToken ct)
{
await Send.OkAsync(await productsRepository.ProjectToListAsync<GetProductDto>(new GetProductsUnderLimitSpec(), ct), ct);
}
}

View File

@@ -18,7 +18,7 @@ public class GetProductEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/products/{@Id}", x => new {x.Id}); Get("/products/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class PatchProductMinimalStockEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/products/{@Id}/MinimalStock", x => new { x.Id }); Patch("/products/{@Id}/MinimalStock", x => new { x.Id });
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class UpdateProductEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Put("/api/products/{@Id}", x => new {x.Id}); Put("/products/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,52 @@
using FastEndpoints;
using PyroFetes.DTO.PurchaseOrder.Request;
using PyroFetes.DTO.PurchaseOrder.Response;
using PyroFetes.DTO.PurchaseProduct.Request;
using PyroFetes.DTO.PurchaseProduct.Response;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Products;
using PyroFetes.Specifications.PurchaseOrders;
namespace PyroFetes.Endpoints.PurchaseOrders;
public class CreatePurchaseOrder(
PurchaseOrdersRepository purchaseOrdersRepository,
ProductsRepository productsRepository,
AutoMapper.IMapper mapper) : Endpoint<CreatePurchaseOrderDto, GetPurchaseOrderDto>
{
public override void Configure()
{
Post("/purchaseOrders");
AllowAnonymous();
}
public override async Task HandleAsync(CreatePurchaseOrderDto req, CancellationToken ct)
{
PurchaseOrder purchaseOrder = new PurchaseOrder
{
PurchaseConditions = req.PurchaseConditions ?? "Conditions non précisées",
PurchaseProducts = new List<PurchaseProduct>()
};
foreach (var line in req.Products)
{
var product = await productsRepository.GetByIdAsync(line.ProductId, ct);
if (product == null)
{
await Send.NotFoundAsync(ct);
return;
}
purchaseOrder.PurchaseProducts.Add(new PurchaseProduct
{
ProductId = product.Id,
Quantity = line.Quantity,
});
}
await purchaseOrdersRepository.AddAsync(purchaseOrder, ct);
await Send.OkAsync(mapper.Map<GetPurchaseOrderDto>(purchaseOrder), ct);
}
}

View File

@@ -17,7 +17,7 @@ public class DeletePurchaseOrderEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/purchaseOrders/{@Id}", x => new {x.Id}); Delete("/purchaseOrders/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -10,7 +10,7 @@ public class GetAllPurchaseOrderEndpoint(PurchaseOrdersRepository purchaseOrders
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/purchaseOrders"); Get("/purchaseOrders");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -19,7 +19,7 @@ public class GetPurchaseOrderEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/purchaseOrders/{@Id}", x => new {x.Id}); Get("/purchaseOrders/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,41 @@
using System.Net.Mime;
using FastEndpoints;
using PyroFetes.DTO.PurchaseOrder.Request;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Services.Pdf;
using PyroFetes.Specifications.PurchaseOrders;
namespace PyroFetes.Endpoints.PurchaseOrders;
public class GetPurchaseOrderPdfEndpoint(
PurchaseOrdersRepository purchaseOrdersRepository,
IPurchaseOrderPdfService purchaseOrderPdfService)
: Endpoint<GetPurchaseOrderPdfDto, byte[]>
{
public override void Configure()
{
Get("/purchaseOrders/{@Id}/pdf", x => new {x.Id});
AllowAnonymous();
Description(b => b.Produces<byte[]>(200, MediaTypeNames.Application.Pdf));
}
public override async Task HandleAsync(GetPurchaseOrderPdfDto req, CancellationToken ct)
{
PurchaseOrder? purchaseOrder = await purchaseOrdersRepository
.FirstOrDefaultAsync(new GetPurchaseOrderByIdWithProductsSpec(req.Id), ct);
if (purchaseOrder == null)
{
await Send.NotFoundAsync(ct);
return;
}
var bytes = purchaseOrderPdfService.Generate(purchaseOrder, purchaseOrder.PurchaseProducts!);
await Send.BytesAsync(
bytes: bytes,
contentType: "application/pdf",
fileName: $"bon-de-commande-{purchaseOrder.Id}.pdf",
cancellation: ct);
}
}

View File

@@ -15,7 +15,7 @@ public class PatchPurchaseOrderPurchaseConditionsEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/purchaseOrders/{@Id}/PurchaseConditions", x => new { x.Id }); Patch("/purchaseOrders/{@Id}/PurchaseConditions", x => new { x.Id });
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -17,7 +17,7 @@ public class CreatePurchaseProductEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/purchaseProducts"); Post("/purchaseProducts");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -16,7 +16,7 @@ public class DeletePurchaseProductEndpoint(PurchaseProductsRepository purchasePr
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/purchaseProducts/{@ProductId}/{@PurchaseOrderId}", x => new {x.ProductId, x.PurchaseOrderId}); Delete("/purchaseProducts/{@ProductId}/{@PurchaseOrderId}", x => new {x.ProductId, x.PurchaseOrderId});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class PatchPurchaseProductQuantityEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/purchaseProducts/{@ProductId}/{@PurchaseOrderId}/Quantity", x => new { x.ProductId, x.PurchaseOrderId }); Patch("/purchaseProducts/{@ProductId}/{@PurchaseOrderId}/Quantity", x => new { x.ProductId, x.PurchaseOrderId });
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -17,7 +17,7 @@ public class CreateQuotationProductEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/quotationProduct"); Post("/quotationProducts");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -16,7 +16,7 @@ public class DeleteQuotationProductEndpoint(QuotationProductsRepository quotatio
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/quotationProduct/{@ProductId}/{@QuotationId}", x => new {x.ProductId, x.QuotationId}); Delete("/quotationProducts/{@ProductId}/{@QuotationId}", x => new {x.ProductId, x.QuotationId});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class PatchQuotationProductQuantityEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/quotationProduct/{@ProductId}/{@QuotationId}/Quantity", x => new { x.ProductId, x.QuotationId }); Patch("/quotationProducts/{@ProductId}/{@QuotationId}/Quantity", x => new { x.ProductId, x.QuotationId });
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,50 @@
using FastEndpoints;
using PyroFetes.DTO.Quotation.Request;
using PyroFetes.DTO.Quotation.Response;
using PyroFetes.Models;
using PyroFetes.Repositories;
namespace PyroFetes.Endpoints.Quotations;
public class CreateQuotationEndpoint(
QuotationsRepository quotationsRepository,
ProductsRepository productsRepository,
AutoMapper.IMapper mapper) : Endpoint<CreateQuotationDto, GetQuotationDto>
{
public override void Configure()
{
Post("/quotations");
AllowAnonymous();
}
public override async Task HandleAsync(CreateQuotationDto req, CancellationToken ct)
{
Quotation quotation = new Quotation
{
Message = req.Message,
ConditionsSale = req.ConditionsSale ?? "Conditions non précisées",
CustomerId = 1, // A changer
QuotationProducts = new List<QuotationProduct>()
};
foreach (var line in req.Products)
{
var product = await productsRepository.GetByIdAsync(line.ProductId, ct);
if (product == null)
{
await Send.NotFoundAsync(ct);
return;
}
quotation.QuotationProducts.Add(new QuotationProduct
{
ProductId = product.Id,
Quantity = line.Quantity,
});
}
await quotationsRepository.AddAsync(quotation, ct);
await Send.OkAsync(mapper.Map<GetQuotationDto>(quotation), ct);
}
}

View File

@@ -17,7 +17,7 @@ public class DeleteQuotationEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/quotations/{@Id}", x => new {x.Id}); Delete("/quotations/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -11,7 +11,7 @@ public class GetAllQuotationEndpoint(QuotationsRepository quotationsRepository)
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/quotations"); Get("/quotations");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -19,7 +19,7 @@ public class GetQuotationEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/quotations/{@Id}", x => new {x.Id}); Get("/quotations/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,42 @@
using System.Net.Mime;
using FastEndpoints;
using PyroFetes.DTO.Quotation.Request;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Services.Pdf;
using PyroFetes.Specifications.Quotations;
namespace PyroFetes.Endpoints.Quotations;
public class GetQuotationPdfEndpoint(
QuotationsRepository quotationRepository,
IQuotationPdfService quotationPdfService)
: Endpoint<GetQuotationPdfDto, byte[]>
{
public override void Configure()
{
Get("/quotations/{@Id}/pdf", x => new {x.Id});
AllowAnonymous();
Description(b => b.Produces<byte[]>(200, MediaTypeNames.Application.Pdf));
}
public override async Task HandleAsync(GetQuotationPdfDto req, CancellationToken ct)
{
Quotation? quotation = await quotationRepository
.FirstOrDefaultAsync(new GetQuotationByIdWithProductsSpec(req.Id), ct);
if (quotation == null)
{
await Send.NotFoundAsync(ct);
return;
}
var bytes = quotationPdfService.Generate(quotation, quotation.QuotationProducts!);
await Send.BytesAsync(
bytes: bytes,
contentType: "application/pdf",
fileName: $"devis-{quotation.Id}.pdf",
cancellation: ct);
}
}

View File

@@ -1,8 +1,6 @@
using FastEndpoints; using FastEndpoints;
using Microsoft.EntityFrameworkCore;
using PyroFetes.DTO.Quotation.Request; using PyroFetes.DTO.Quotation.Request;
using PyroFetes.DTO.Quotation.Response; using PyroFetes.DTO.Quotation.Response;
using PyroFetes.DTO.QuotationProduct.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories; using PyroFetes.Repositories;
using PyroFetes.Specifications.Quotations; using PyroFetes.Specifications.Quotations;
@@ -15,7 +13,7 @@ public class PatchQuotationConditionsSaleEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/quotations/{@Id}/ConditionsSale", x => new { x.Id }); Patch("/quotations/{@Id}/saleConditions", x => new { x.Id });
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -0,0 +1,36 @@
using FastEndpoints;
using PyroFetes.DTO.Quotation.Request;
using PyroFetes.DTO.Quotation.Response;
using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Quotations;
namespace PyroFetes.Endpoints.Quotations;
public class UpdateQuotationEndpoint(
QuotationsRepository quotationsRepository,
AutoMapper.IMapper mapper) : Endpoint<UpdateQuotationDto, GetQuotationDto>
{
public override void Configure()
{
Put("/quotations/{@Id}", x => new { x.Id });
AllowAnonymous();
}
public override async Task HandleAsync(UpdateQuotationDto req, CancellationToken ct)
{
Quotation? quotation = await quotationsRepository.FirstOrDefaultAsync(new GetQuotationByIdSpec(req.Id), ct);
if (quotation == null)
{
await Send.NotFoundAsync(ct);
return;
}
quotation.ConditionsSale = req.ConditionsSale;
quotation.Message = req.Message;
await quotationsRepository.UpdateAsync(quotation, ct);
await Send.OkAsync(mapper.Map<GetQuotationDto>(quotation), ct);
}
}

View File

@@ -12,7 +12,7 @@ public class CreateSettingEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/setting"); Post("/settings");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -15,7 +15,7 @@ public class DeleteSettingEndpoint(SettingsRepository settingsRepository) : Endp
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/setting/{@Id}", x => new {x.Id}); Delete("/settings/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -18,7 +18,7 @@ public class GetSettingEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/setting/{@Id}", x => new {x.Id}); Get("/settings/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class PatchSettingElectronicSignatureEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/setting/{@Id}/ElectronicSignature", x => new {x.Id}); Patch("/settings/{@Id}/ElectronicSignature", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class PatchSettingLogoEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/setting/{@Id}/Logo", x => new {x.Id}); Patch("/settings/{@Id}/logo", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -12,7 +12,7 @@ public class CreateSupplierEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/suppliers"); Post("/suppliers");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -15,7 +15,7 @@ public class DeleteSupplierEndpoint(SuppliersRepository suppliersRepository) : E
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/suppliers/{@Id}", x => new {x.Id}); Delete("/suppliers/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -9,7 +9,7 @@ public class GetAllSuppliersEndpoint(SuppliersRepository suppliersRepository) :
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/suppliers"); Get("/suppliers");
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -18,7 +18,7 @@ public class GetSupplierEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/suppliers/{@Id}", x => new {x.Id}); Get("/suppliers/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -8,13 +8,13 @@ using PyroFetes.Specifications.Suppliers;
namespace PyroFetes.Endpoints.Suppliers; namespace PyroFetes.Endpoints.Suppliers;
public class PatchSupplierDeleveryDelayEndpoint( public class PatchSupplierDeliveryDelayEndpoint(
SuppliersRepository suppliersRepository, SuppliersRepository suppliersRepository,
AutoMapper.IMapper mapper) : Endpoint<PatchSupplierDeliveryDelayDto, GetSupplierDto> AutoMapper.IMapper mapper) : Endpoint<PatchSupplierDeliveryDelayDto, GetSupplierDto>
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/supplier/{@Id}/DeleveryDalay", x => new {x.Id}); Patch("/suppliers/{@Id}/deliveryDelay", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -14,7 +14,7 @@ public class UpdateSupplierEndpoint(
{ {
public override void Configure() public override void Configure()
{ {
Put("/api/suppliers/{@Id}", x => new {x.Id}); Put("/suppliers/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }

View File

@@ -4,20 +4,22 @@ using Microsoft.EntityFrameworkCore;
using PyroFetes.DTO.User.Request; using PyroFetes.DTO.User.Request;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Users;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
public class ConnectUserEndpoint(PyroFetesDbContext database) : Endpoint<ConnectUserDto, GetTokenDto> public class ConnectUserEndpoint(UsersRepository usersRepository) : Endpoint<ConnectUserDto, GetTokenDto>
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/users/connect"); Post("/users/connection");
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(ConnectUserDto req, CancellationToken ct) public override async Task HandleAsync(ConnectUserDto req, CancellationToken ct)
{ {
User? user = await database.Users.SingleOrDefaultAsync(x => x.Name == req.Name, ct); User? user = await usersRepository.FirstOrDefaultAsync(new GetUserByNameSpec(req.Name!), ct);
if (user == null) if (user == null)
{ {

View File

@@ -3,19 +3,31 @@ using PasswordGenerator;
using PyroFetes.DTO.User.Request; using PyroFetes.DTO.User.Request;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Users;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
public class CreateUserEndpoint(PyroFetesDbContext database) : Endpoint<CreateUserDto, GetUserDto> public class CreateUserEndpoint(
UsersRepository usersRepository,
AutoMapper.IMapper mapper) : Endpoint<CreateUserDto, GetUserDto>
{ {
public override void Configure() public override void Configure()
{ {
Post("/api/users"); Post("/users");
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(CreateUserDto req, CancellationToken ct) public override async Task HandleAsync(CreateUserDto req, CancellationToken ct)
{ {
User? ckeckName = await usersRepository.FirstOrDefaultAsync(new GetUserByNameSpec(req.Name!), ct);
if (ckeckName != null)
{
await Send.StringAsync("Ce nom d'utilisateur existe déjà.",409, cancellation: ct);
return;
}
string? salt = new Password().IncludeLowercase().IncludeUppercase().IncludeNumeric().LengthRequired(24).Next(); string? salt = new Password().IncludeLowercase().IncludeUppercase().IncludeNumeric().LengthRequired(24).Next();
User user = new User() User user = new User()
@@ -27,20 +39,8 @@ public class CreateUserEndpoint(PyroFetesDbContext database) : Endpoint<CreateUs
Fonction = req.Fonction Fonction = req.Fonction
}; };
database.Users.Add(user); await usersRepository.AddAsync(user, ct);
await database.SaveChangesAsync(ct); await Send.OkAsync(mapper.Map<GetUserDto>(user), ct);
GetUserDto responseDto = new()
{
Id = user.Id,
Name = user.Name,
Password = user.Password,
Salt = user.Salt,
Email = user.Email,
Fonction = user.Fonction
};
await Send.OkAsync(responseDto, ct);
} }
} }

View File

@@ -1,6 +1,8 @@
using FastEndpoints; using FastEndpoints;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Users;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
@@ -9,17 +11,17 @@ public class DeleteUserRequest
public int Id { get; set; } public int Id { get; set; }
} }
public class DeleteUserEndpoint(PyroFetesDbContext database) : Endpoint<DeleteUserRequest> public class DeleteUserEndpoint(UsersRepository usersRepository) : Endpoint<DeleteUserRequest>
{ {
public override void Configure() public override void Configure()
{ {
Delete("/api/users/{@Id}", x => new {x.Id}); Delete("/users/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(DeleteUserRequest req, CancellationToken ct) public override async Task HandleAsync(DeleteUserRequest req, CancellationToken ct)
{ {
User? user = await database.Users.SingleOrDefaultAsync(x => x.Id == req.Id, ct); User? user = await usersRepository.FirstOrDefaultAsync(new GetUserByIdSpec(req.Id), ct);
if (user == null) if (user == null)
{ {
@@ -27,8 +29,7 @@ public class DeleteUserEndpoint(PyroFetesDbContext database) : Endpoint<DeleteUs
return; return;
} }
database.Users.Remove(user); await usersRepository.DeleteAsync(user, ct);
await database.SaveChangesAsync(ct);
await Send.NoContentAsync(ct); await Send.NoContentAsync(ct);
} }

View File

@@ -1,31 +1,20 @@
using FastEndpoints; using FastEndpoints;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.Repositories;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
public class GetAllUsersEndpoint(PyroFetesDbContext database) : EndpointWithoutRequest<List<GetUserDto>> public class GetAllUsersEndpoint(UsersRepository usersRepository) : EndpointWithoutRequest<List<GetUserDto>>
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/users"); Get("/users");
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(CancellationToken ct) public override async Task HandleAsync(CancellationToken ct)
{ {
List<GetUserDto> users = await database.Users await Send.OkAsync(await usersRepository.ProjectToListAsync<GetUserDto>(ct), ct);
.Select(users => new GetUserDto()
{
Id = users.Id,
Name = users.Name,
Password = users.Password,
Salt = users.Salt,
Email = users.Email,
Fonction = users.Fonction
})
.ToListAsync(ct);
await Send.OkAsync(users, ct);
} }
} }

View File

@@ -2,6 +2,8 @@
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Users;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
@@ -10,18 +12,19 @@ public class GetUserRequest
public int Id { get; set; } public int Id { get; set; }
} }
public class GetUserEndpoint(PyroFetesDbContext database) : Endpoint<GetUserRequest, GetUserDto> public class GetUserEndpoint(
UsersRepository usersRepository,
AutoMapper.IMapper mapper) : Endpoint<GetUserRequest, GetUserDto>
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/users/{@Id}", x => new {x.Id}); Get("/users/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(GetUserRequest req, CancellationToken ct) public override async Task HandleAsync(GetUserRequest req, CancellationToken ct)
{ {
User? user = await database.Users User? user = await usersRepository.FirstOrDefaultAsync(new GetUserByIdSpec(req.Id), ct);
.SingleOrDefaultAsync(x => x.Id == req.Id, ct);
if (user == null) if (user == null)
{ {
@@ -29,16 +32,6 @@ public class GetUserEndpoint(PyroFetesDbContext database) : Endpoint<GetUserRequ
return; return;
} }
GetUserDto responseDto = new() await Send.OkAsync(mapper.Map<GetUserDto>(user), ct);
{
Id = user.Id,
Name = user.Name,
Password = user.Password,
Salt = user.Salt,
Email = user.Email,
Fonction = user.Fonction
};
await Send.OkAsync(responseDto, ct);
} }
} }

View File

@@ -3,20 +3,25 @@ using Microsoft.EntityFrameworkCore;
using PyroFetes.DTO.User.Request; using PyroFetes.DTO.User.Request;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Users;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
public class PatchUserPasswordEndpoint(PyroFetesDbContext database) : Endpoint<PatchUserPasswordDto, GetUserDto> public class PatchUserPasswordEndpoint(
UsersRepository usersRepository,
AutoMapper.IMapper mapper) : Endpoint<PatchUserPasswordDto, GetUserDto>
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/users/{@Id}/Password", x => new { x.Id }); Patch("/users/{@Id}/password", x => new { x.Id });
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(PatchUserPasswordDto req, CancellationToken ct) public override async Task HandleAsync(PatchUserPasswordDto req, CancellationToken ct)
{ {
User? user = await database.Users.SingleOrDefaultAsync(x => x.Id == req.Id, ct); User? user = await usersRepository.FirstOrDefaultAsync(new GetUserByIdSpec(req.Id), ct);
if (user == null) if (user == null)
{ {
await Send.NotFoundAsync(ct); await Send.NotFoundAsync(ct);
@@ -24,17 +29,8 @@ public class PatchUserPasswordEndpoint(PyroFetesDbContext database) : Endpoint<P
} }
user.Password = BCrypt.Net.BCrypt.HashPassword(req.Password + user.Salt); user.Password = BCrypt.Net.BCrypt.HashPassword(req.Password + user.Salt);
await database.SaveChangesAsync(ct); await usersRepository.UpdateAsync(user, ct);
GetUserDto responseDto = new() await Send.OkAsync(mapper.Map<GetUserDto>(user), ct);
{
Id = user.Id,
Name = user.Name,
Password = user.Password,
Salt = user.Salt,
Email = user.Email,
Fonction = user.Fonction
};
await Send.OkAsync(responseDto, ct);
} }
} }

View File

@@ -4,21 +4,25 @@ using PasswordGenerator;
using PyroFetes.DTO.User.Request; using PyroFetes.DTO.User.Request;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.Users;
namespace PyroFetes.Endpoints.Users; namespace PyroFetes.Endpoints.Users;
public class UpdateUserEndpoint(PyroFetesDbContext database) : Endpoint<UpdateUserDto, GetUserDto> public class UpdateUserEndpoint(
UsersRepository usersRepository,
AutoMapper.IMapper mapper) : Endpoint<UpdateUserDto, GetUserDto>
{ {
public override void Configure() public override void Configure()
{ {
Put("/api/users/{@Id}", x => new {x.Id}); Put("/users/{@Id}", x => new {x.Id});
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(UpdateUserDto req, CancellationToken ct) public override async Task HandleAsync(UpdateUserDto req, CancellationToken ct)
{ {
User? user = await database.Users.SingleOrDefaultAsync(x => x.Id == req.Id, ct); User? user = await usersRepository.FirstOrDefaultAsync(new GetUserByIdSpec(req.Id), ct);
User? ckeckName = await database.Users.SingleOrDefaultAsync(x => x.Name == req.Name, ct); User? ckeckName = await usersRepository.FirstOrDefaultAsync(new GetUserByNameSpec(req.Name!), ct);
if (user == null) if (user == null)
{ {
@@ -26,7 +30,7 @@ public class UpdateUserEndpoint(PyroFetesDbContext database) : Endpoint<UpdateUs
return; return;
} }
if (ckeckName != null) if (ckeckName != null && ckeckName.Id != user.Id)
{ {
await Send.StringAsync("Ce nom d'utilisateur existe déjà.",409, cancellation: ct); await Send.StringAsync("Ce nom d'utilisateur existe déjà.",409, cancellation: ct);
return; return;
@@ -39,18 +43,9 @@ public class UpdateUserEndpoint(PyroFetesDbContext database) : Endpoint<UpdateUs
user.Salt = salt; user.Salt = salt;
user.Email = req.Email; user.Email = req.Email;
user.Fonction = req.Fonction; user.Fonction = req.Fonction;
await database.SaveChangesAsync(ct);
GetUserDto responseDto = new() await usersRepository.UpdateAsync(user, ct);
{
Id = user.Id,
Name = user.Name,
Password = user.Password,
Salt = user.Salt,
Email = user.Email,
Fonction = user.Fonction
};
await Send.OkAsync(responseDto, ct); await Send.OkAsync(mapper.Map<GetUserDto>(user), ct);
} }
} }

View File

@@ -2,6 +2,8 @@
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using PyroFetes.DTO.WareHouseProduct.Response; using PyroFetes.DTO.WareHouseProduct.Response;
using PyroFetes.Models; using PyroFetes.Models;
using PyroFetes.Repositories;
using PyroFetes.Specifications.WarehouseProducts;
namespace PyroFetes.Endpoints.WareHouseProducts; namespace PyroFetes.Endpoints.WareHouseProducts;
@@ -10,18 +12,18 @@ public class GetTotalQuantityRequest
public int ProductId { get; set; } public int ProductId { get; set; }
} }
public class GetTotalQuantityEndpoint(PyroFetesDbContext database) : Endpoint<GetTotalQuantityRequest, GetTotalQuantityDto> public class GetTotalQuantityEndpoint(
WarehouseProductsRepository warehouseProductsRepository) : Endpoint<GetTotalQuantityRequest, GetTotalQuantityDto>
{ {
public override void Configure() public override void Configure()
{ {
Get("/api/wareHouseProduct/{@ProductId}", x => new { x.ProductId }); Get("/wareHouseProducts/{@ProductId}", x => new { x.ProductId });
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(GetTotalQuantityRequest req, CancellationToken ct) public override async Task HandleAsync(GetTotalQuantityRequest req, CancellationToken ct)
{ {
bool exists = await database.WarehouseProducts bool exists = await warehouseProductsRepository.AnyAsync(new GetWarehouseProductByProductIdSpec(req.ProductId), ct);
.AnyAsync(wp => wp.ProductId == req.ProductId, ct);
if (!exists) if (!exists)
{ {
@@ -29,9 +31,10 @@ public class GetTotalQuantityEndpoint(PyroFetesDbContext database) : Endpoint<Ge
return; return;
} }
int totalQuantity = await database.WarehouseProducts int? totalQuantityNullable = await warehouseProductsRepository.
.Where(wp => wp.ProductId == req.ProductId) SumAsync(new GetProductTotalQuantitySpec(req.ProductId), wp => wp.Quantity, ct);
.SumAsync(wp => wp.Quantity, ct);
int totalQuantity = totalQuantityNullable ?? 0;
GetTotalQuantityDto responseDto = new() GetTotalQuantityDto responseDto = new()
{ {

View File

@@ -6,23 +6,27 @@ using PyroFetes.Models;
namespace PyroFetes.Endpoints.WareHouseProducts; namespace PyroFetes.Endpoints.WareHouseProducts;
public class PatchWareHouseProductQuantityEndpoint(PyroFetesDbContext database) : Endpoint<PatchWareHouseProductQuantityDto, GetWareHouseProductDto> public class PatchWareHouseProductQuantityEndpoint(PyroFetesDbContext database)
: Endpoint<PatchWareHouseProductQuantityDto, GetWareHouseProductDto>
{ {
public override void Configure() public override void Configure()
{ {
Patch("/api/wareHouseProduct/{@ProductId}/{@WareHouseId}/Quantity", x => new { x.ProductId, x.WareHouseId }); Patch("/wareHouseProducts/{@ProductId}/{@WareHouseId}/quantity", x => new { x.ProductId, x.WareHouseId });
AllowAnonymous(); AllowAnonymous();
} }
public override async Task HandleAsync(PatchWareHouseProductQuantityDto req, CancellationToken ct) public override async Task HandleAsync(PatchWareHouseProductQuantityDto req, CancellationToken ct)
{ {
WarehouseProduct? wareHouseProduct = await database.WarehouseProducts.SingleOrDefaultAsync(wp => wp.ProductId == req.ProductId && wp.WarehouseId == req.WareHouseId, ct); WarehouseProduct? wareHouseProduct =
await database.WarehouseProducts.SingleOrDefaultAsync(
wp => wp.ProductId == req.ProductId && wp.WarehouseId == req.WareHouseId, ct);
if (wareHouseProduct == null) if (wareHouseProduct == null)
{ {
await Send.NotFoundAsync(ct); await Send.NotFoundAsync(ct);
return; return;
} }
wareHouseProduct.Quantity = req.Quantity; wareHouseProduct.Quantity = req.Quantity;
await database.SaveChangesAsync(ct); await database.SaveChangesAsync(ct);

View File

@@ -38,6 +38,7 @@ public class DtoToEntityMappings : Profile
CreateMap<CreateProductDeliveryDto, ProductDelivery>(); CreateMap<CreateProductDeliveryDto, ProductDelivery>();
CreateMap<UpdateProductDeliveryDto, ProductDelivery>(); CreateMap<UpdateProductDeliveryDto, ProductDelivery>();
CreateMap<CreatePurchaseOrderDto, PurchaseOrder>();
CreateMap<PatchPurchaseOrderPurchaseConditionsDto,PurchaseOrder>(); CreateMap<PatchPurchaseOrderPurchaseConditionsDto,PurchaseOrder>();
CreateMap<CreatePurchaseProductDto, PurchaseProduct>(); CreateMap<CreatePurchaseProductDto, PurchaseProduct>();
@@ -46,6 +47,7 @@ public class DtoToEntityMappings : Profile
CreateMap<PatchQuotationConditionsSaleDto, Quotation>(); CreateMap<PatchQuotationConditionsSaleDto, Quotation>();
CreateMap<PatchQuotationMessageDto, Quotation>(); CreateMap<PatchQuotationMessageDto, Quotation>();
CreateMap<CreateProductQuotationDto, Quotation>();
CreateMap<CreateQuotationProductDto, QuotationProduct>(); CreateMap<CreateQuotationProductDto, QuotationProduct>();
CreateMap<UpdateQuotationProductDto, QuotationProduct>(); CreateMap<UpdateQuotationProductDto, QuotationProduct>();

View File

@@ -9,6 +9,7 @@ using PyroFetes.DTO.PurchaseProduct.Response;
using PyroFetes.DTO.Quotation.Response; using PyroFetes.DTO.Quotation.Response;
using PyroFetes.DTO.QuotationProduct.Response; using PyroFetes.DTO.QuotationProduct.Response;
using PyroFetes.DTO.SettingDTO.Response; using PyroFetes.DTO.SettingDTO.Response;
using PyroFetes.DTO.Supplier.Response;
using PyroFetes.DTO.User.Response; using PyroFetes.DTO.User.Response;
using PyroFetes.DTO.WareHouseProduct.Response; using PyroFetes.DTO.WareHouseProduct.Response;
using PyroFetes.Models; using PyroFetes.Models;
@@ -21,6 +22,8 @@ public class EntityToDtoMappings : Profile
{ {
CreateMap<Deliverer, GetDelivererDto>(); CreateMap<Deliverer, GetDelivererDto>();
CreateMap<Supplier, GetSupplierDto>();
CreateMap<DeliveryNote, GetDeliveryNoteDto>(); CreateMap<DeliveryNote, GetDeliveryNoteDto>();
CreateMap<Price, GetPriceDto>(); CreateMap<Price, GetPriceDto>();
@@ -29,13 +32,33 @@ public class EntityToDtoMappings : Profile
CreateMap<ProductDelivery, GetProductDeliveryDto>(); CreateMap<ProductDelivery, GetProductDeliveryDto>();
CreateMap<PurchaseOrder, GetPurchaseOrderDto>(); // CreateMap<PurchaseOrder, GetPurchaseOrderDto>();
//
// CreateMap<PurchaseProduct, GetPurchaseProductDto>();
CreateMap<PurchaseProduct, GetPurchaseProductDto>(); CreateMap<PurchaseOrder, GetPurchaseOrderDto>()
.ForMember(dest => dest.Products,
opt => opt.MapFrom(src => src.PurchaseProducts));
CreateMap<PurchaseProduct, GetPurchaseProductDto>()
.ForMember(dest => dest.ProductId, opt => opt.MapFrom(src => src.ProductId))
.ForMember(dest => dest.Quantity, opt => opt.MapFrom(src => src.Quantity))
.ForMember(dest => dest.ProductName, opt => opt.MapFrom(src => src.Product.Name))
.ForMember(dest => dest.ProductReferences, opt => opt.MapFrom(src => src.Product.Reference));
CreateMap<Quotation, GetQuotationDto>(); // CreateMap<Quotation, GetQuotationDto>();
//
// CreateMap<QuotationProduct, GetQuotationProductDto>();
CreateMap<QuotationProduct, GetQuotationProductDto>(); CreateMap<Quotation, GetQuotationDto>()
.ForMember(dest => dest.Products,
opt => opt.MapFrom(src => src.QuotationProducts));
CreateMap<QuotationProduct, GetQuotationProductDto>()
.ForMember(dest => dest.ProductId, opt => opt.MapFrom(src => src.ProductId))
.ForMember(dest => dest.Quantity, opt => opt.MapFrom(src => src.Quantity))
.ForMember(dest => dest.ProductName, opt => opt.MapFrom(src => src.Product.Name))
.ForMember(dest => dest.ProductReferences, opt => opt.MapFrom(src => src.Product.Reference));
CreateMap<Setting, GetSettingDto>(); CreateMap<Setting, GetSettingDto>();

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,68 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace PyroFetes.Migrations
{
/// <inheritdoc />
public partial class FixTypeErrors : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "ZipCode",
table: "Suppliers",
type: "nvarchar(5)",
maxLength: 5,
nullable: false,
oldClrType: typeof(int),
oldType: "int");
migrationBuilder.AlterColumn<int>(
name: "Caliber",
table: "Products",
type: "int",
nullable: false,
oldClrType: typeof(decimal),
oldType: "decimal(18,2)");
migrationBuilder.AlterColumn<string>(
name: "ApprovalNumber",
table: "Products",
type: "nvarchar(max)",
nullable: false,
oldClrType: typeof(int),
oldType: "int");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<int>(
name: "ZipCode",
table: "Suppliers",
type: "int",
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(5)",
oldMaxLength: 5);
migrationBuilder.AlterColumn<decimal>(
name: "Caliber",
table: "Products",
type: "decimal(18,2)",
nullable: false,
oldClrType: typeof(int),
oldType: "int");
migrationBuilder.AlterColumn<int>(
name: "ApprovalNumber",
table: "Products",
type: "int",
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(max)");
}
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,36 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace PyroFetes.Migrations
{
/// <inheritdoc />
public partial class UpdatedDatabaseProductType : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "ApprovalNumber",
table: "Products",
type: "nvarchar(100)",
maxLength: 100,
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(max)");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "ApprovalNumber",
table: "Products",
type: "nvarchar(max)",
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(100)",
oldMaxLength: 100);
}
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,38 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace PyroFetes.Migrations
{
/// <inheritdoc />
public partial class UpdatedLengthOfPassword : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "Password",
table: "Users",
type: "nvarchar(60)",
maxLength: 60,
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(50)",
oldMaxLength: 50);
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "Password",
table: "Users",
type: "nvarchar(50)",
maxLength: 50,
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(60)",
oldMaxLength: 60);
}
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,52 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace PyroFetes.Migrations
{
/// <inheritdoc />
public partial class FixZipCode : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<string>(
name: "ZipCode",
table: "Warehouses",
type: "nvarchar(max)",
nullable: false,
oldClrType: typeof(int),
oldType: "int");
migrationBuilder.AlterColumn<string>(
name: "ZipCode",
table: "Suppliers",
type: "nvarchar(max)",
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(5)",
oldMaxLength: 5);
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.AlterColumn<int>(
name: "ZipCode",
table: "Warehouses",
type: "int",
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(max)");
migrationBuilder.AlterColumn<string>(
name: "ZipCode",
table: "Suppliers",
type: "nvarchar(5)",
maxLength: 5,
nullable: false,
oldClrType: typeof(string),
oldType: "nvarchar(max)");
}
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,22 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace PyroFetes.Migrations
{
/// <inheritdoc />
public partial class FixProductTypes : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
}
}
}

View File

@@ -503,11 +503,13 @@ namespace PyroFetes.Migrations
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id")); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ApprovalNumber") b.Property<string>("ApprovalNumber")
.HasColumnType("int"); .IsRequired()
.HasMaxLength(100)
.HasColumnType("nvarchar(100)");
b.Property<decimal>("Caliber") b.Property<int>("Caliber")
.HasColumnType("decimal(18,2)"); .HasColumnType("int");
b.Property<int>("ClassificationId") b.Property<int>("ClassificationId")
.HasColumnType("int"); .HasColumnType("int");
@@ -1113,8 +1115,9 @@ namespace PyroFetes.Migrations
.HasMaxLength(30) .HasMaxLength(30)
.HasColumnType("nvarchar(30)"); .HasColumnType("nvarchar(30)");
b.Property<int>("ZipCode") b.Property<string>("ZipCode")
.HasColumnType("int"); .IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id"); b.HasKey("Id");
@@ -1178,8 +1181,8 @@ namespace PyroFetes.Migrations
b.Property<string>("Password") b.Property<string>("Password")
.IsRequired() .IsRequired()
.HasMaxLength(50) .HasMaxLength(60)
.HasColumnType("nvarchar(50)"); .HasColumnType("nvarchar(60)");
b.Property<string>("Salt") b.Property<string>("Salt")
.IsRequired() .IsRequired()
@@ -1223,8 +1226,9 @@ namespace PyroFetes.Migrations
.HasMaxLength(100) .HasMaxLength(100)
.HasColumnType("nvarchar(100)"); .HasColumnType("nvarchar(100)");
b.Property<int>("ZipCode") b.Property<string>("ZipCode")
.HasColumnType("int"); .IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id"); b.HasKey("Id");

View File

@@ -8,8 +8,8 @@ namespace PyroFetes.Models
[Required, MaxLength(20)] public string? Reference { get; set; } [Required, MaxLength(20)] public string? Reference { get; set; }
[Required, MaxLength(100)] public string? Name { get; set; } [Required, MaxLength(100)] public string? Name { get; set; }
[Required] public decimal Duration {get; set;} [Required] public decimal Duration {get; set;}
[Required] public decimal Caliber { get; set; } [Required] public int Caliber { get; set; }
[Required] public int ApprovalNumber { get; set; } [Required, MaxLength(100)] public string? ApprovalNumber { get; set; }
[Required] public decimal Weight { get; set; } [Required] public decimal Weight { get; set; }
[Required] public decimal Nec { get; set; } [Required] public decimal Nec { get; set; }
[Required] public string? Image { get; set; } [Required] public string? Image { get; set; }

View File

@@ -9,7 +9,7 @@ public class Supplier
[Required, MaxLength(100)] public string? Email { get; set; } [Required, MaxLength(100)] public string? Email { get; set; }
[Required, MaxLength(30)] public string? Phone { get; set; } [Required, MaxLength(30)] public string? Phone { get; set; }
[Required, MaxLength(100)] public string? Address { get; set; } [Required, MaxLength(100)] public string? Address { get; set; }
[Required,MaxLength(5),MinLength(5)] public string? ZipCode { get; set; } [Required,Length(5,5)] public string? ZipCode { get; set; }
[Required, MaxLength(100)] public string? City { get; set; } [Required, MaxLength(100)] public string? City { get; set; }
[Required] public int DeliveryDelay { get; set; } [Required] public int DeliveryDelay { get; set; }

View File

@@ -6,7 +6,7 @@ public class User
{ {
[Key] public int Id { get; set; } [Key] public int Id { get; set; }
[Required, MaxLength(100)] public string? Name { get; set; } [Required, MaxLength(100)] public string? Name { get; set; }
[Required, MinLength(12), MaxLength(50)] public string? Password { get; set; } [Required, MaxLength(60)] public string? Password { get; set; }
[Required, MaxLength(100)] public string? Salt { get; set; } [Required, MaxLength(100)] public string? Salt { get; set; }
[Required, MaxLength(100)] public string? Email { get; set; } [Required, MaxLength(100)] public string? Email { get; set; }
[Required, MaxLength(100)] public string? Fonction { get; set; } [Required, MaxLength(100)] public string? Fonction { get; set; }

View File

@@ -10,7 +10,7 @@ public class Warehouse
[Required] public int Current {get; set;} [Required] public int Current {get; set;}
[Required] public int MinWeight {get; set;} [Required] public int MinWeight {get; set;}
[Required, MaxLength(100)] public string? Address { get; set; } [Required, MaxLength(100)] public string? Address { get; set; }
[Required] public int ZipCode { get; set; } [Required, Length(5,5)] public string? ZipCode { get; set; }
[Required, MaxLength(100)] public string? City { get; set; } [Required, MaxLength(100)] public string? City { get; set; }
public List<WarehouseProduct>? WarehouseProducts { get; set; } public List<WarehouseProduct>? WarehouseProducts { get; set; }

View File

@@ -4,17 +4,37 @@ using PyroFetes;
using FastEndpoints; using FastEndpoints;
using FastEndpoints.Swagger; using FastEndpoints.Swagger;
using FastEndpoints.Security; using FastEndpoints.Security;
using Microsoft.Net.Http.Headers;
using PyroFetes.MappingProfiles; using PyroFetes.MappingProfiles;
using PyroFetes.Repositories; using PyroFetes.Repositories;
using PyroFetes.Services.Pdf;
using QuestPDF.Infrastructure;
WebApplicationBuilder builder = WebApplication.CreateBuilder(args); WebApplicationBuilder builder = WebApplication.CreateBuilder(args);
// Configurer la licence QuestPDF
QuestPDF.Settings.License = LicenseType.Community;
// On ajoute ici FastEndpoints, un framework REPR et Swagger aux services disponibles dans le projet // On ajoute ici FastEndpoints, un framework REPR et Swagger aux services disponibles dans le projet
builder.Services builder.Services
.AddAuthenticationJwtBearer(s => s.SigningKey = "ThisIsASuperSecretJwtKeyThatIsAtLeast32CharsLong") .AddAuthenticationJwtBearer(s => s.SigningKey = "ThisIsASuperSecretJwtKeyThatIsAtLeast32CharsLong")
.AddAuthorization() .AddAuthorization()
.AddFastEndpoints() .AddFastEndpoints()
.SwaggerDocument(); .SwaggerDocument(options =>
{
options.ShortSchemaNames = true;
})
.AddCors(options =>
{
options.AddDefaultPolicy(policyBuilder =>
{
policyBuilder
.WithOrigins("http://localhost:4200")
.WithMethods("GET", "POST", "PUT", "DELETE", "PATCH")
.AllowAnyHeader()
.WithExposedHeaders(HeaderNames.ContentDisposition);
});
});
// On ajoute ici la configuration de la base de données // On ajoute ici la configuration de la base de données
builder.Services.AddDbContext<PyroFetesDbContext>(); builder.Services.AddDbContext<PyroFetesDbContext>();
@@ -30,6 +50,13 @@ builder.Services.AddScoped<QuotationProductsRepository>();
builder.Services.AddScoped<QuotationsRepository>(); builder.Services.AddScoped<QuotationsRepository>();
builder.Services.AddScoped<SuppliersRepository>(); builder.Services.AddScoped<SuppliersRepository>();
builder.Services.AddScoped<SettingsRepository>(); builder.Services.AddScoped<SettingsRepository>();
builder.Services.AddScoped<UsersRepository>();
builder.Services.AddScoped<WarehouseProductsRepository>();
// Ajout des services
builder.Services.AddScoped<IDeliveryNotePdfService, DeliveryNotePdfService>();
builder.Services.AddScoped<IPurchaseOrderPdfService, PurchaseOrderPdfService>();
builder.Services.AddScoped<IQuotationPdfService, QuotationPdfService>();
MapperConfiguration mappingConfig = new(mc => MapperConfiguration mappingConfig = new(mc =>
{ {
@@ -46,9 +73,15 @@ builder.Services.AddSingleton(mapper);
WebApplication app = builder.Build(); WebApplication app = builder.Build();
app.UseAuthentication() app.UseAuthentication()
.UseAuthorization() .UseAuthorization()
.UseFastEndpoints() .UseFastEndpoints(options =>
{
options.Endpoints.ShortNames = true;
options.Endpoints.RoutePrefix = "API";
})
.UseSwaggerGen(); .UseSwaggerGen();
app.UseHttpsRedirection(); app.UseHttpsRedirection();
app.UseCors();
app.Run(); app.Run();

Some files were not shown because too many files have changed in this diff Show More