Compare commits
	
		
			4 Commits
		
	
	
		
			feature/Cr
			...
			develop
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 06c64a9f3f | |||
| aa1c98d649 | |||
| fa72c6d777 | |||
| 59628717d4 | 
							
								
								
									
										7
									
								
								PyroFetes/DTO/User/Request/ConnectUserDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								PyroFetes/DTO/User/Request/ConnectUserDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | namespace PyroFetes.DTO.User.Request; | ||||||
|  |  | ||||||
|  | public class ConnectUserDto | ||||||
|  | { | ||||||
|  |     public string? Username { get; set; } | ||||||
|  |     public string? Password { get; set; } | ||||||
|  | } | ||||||
							
								
								
									
										6
									
								
								PyroFetes/DTO/User/Response/GetTokenDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								PyroFetes/DTO/User/Response/GetTokenDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | namespace PyroFetes.DTO.User.Response; | ||||||
|  |  | ||||||
|  | public class GetTokenDto | ||||||
|  | { | ||||||
|  |     public string? Token { get; set; } | ||||||
|  | } | ||||||
| @@ -1,27 +0,0 @@ | |||||||
| namespace PyroFetes.DTO.WareHouseProduct.Request; |  | ||||||
|  |  | ||||||
| public class CreateWareHouseProductDto |  | ||||||
| { |  | ||||||
|     public int Quantity { get; set; } |  | ||||||
|      |  | ||||||
|     public int WareHouseId { get; set; } |  | ||||||
|     public string? WareHouseName {get; set;} |  | ||||||
|     public int WareHouseMaxWeight {get; set;} |  | ||||||
|     public int WareHouseCurrent {get; set;} |  | ||||||
|     public int WareHouseMinWeight {get; set;} |  | ||||||
|     public string? WareHouseAddress { get; set; } |  | ||||||
|     public int WareHouseZipCode { get; set; } |  | ||||||
|     public string? WareHouseCity { get; set; } |  | ||||||
|      |  | ||||||
|     public int ProductId { get; set; } |  | ||||||
|     public int ProductReferences { get; set; } |  | ||||||
|     public string? ProductName { get; set; } |  | ||||||
|     public decimal ProductDuration {get; set;}  |  | ||||||
|     public decimal ProductCaliber { get; set; } |  | ||||||
|     public int ProductApprovalNumber { get; set; } |  | ||||||
|     public decimal ProductWeight { get; set; } |  | ||||||
|     public decimal ProductNec { get; set; } |  | ||||||
|     public string? ProductImage { get; set; } |  | ||||||
|     public string? ProductLink { get; set; } |  | ||||||
|     public int ProductMinimalQuantity { get; set; } |  | ||||||
| } |  | ||||||
| @@ -2,6 +2,7 @@ namespace PyroFetes.DTO.WareHouseProduct.Request; | |||||||
|  |  | ||||||
| public class PatchWareHouseProductQuantityDto | public class PatchWareHouseProductQuantityDto | ||||||
| { | { | ||||||
|     public int Id { get; set; } |     public int WareHouseId { get; set; } | ||||||
|  |     public int ProductId { get; set; } | ||||||
|     public int Quantity { get; set; } |     public int Quantity { get; set; } | ||||||
| } | } | ||||||
| @@ -1,28 +0,0 @@ | |||||||
| namespace PyroFetes.DTO.WareHouseProduct.Request; |  | ||||||
|  |  | ||||||
| public class UpdateWareHouseProductDto |  | ||||||
| { |  | ||||||
|     public int Id { get; set; } |  | ||||||
|     public int Quantity { get; set; } |  | ||||||
|      |  | ||||||
|     public int WareHouseId { get; set; } |  | ||||||
|     public string? WareHouseName {get; set;} |  | ||||||
|     public int WareHouseMaxWeight {get; set;} |  | ||||||
|     public int WareHouseCurrent {get; set;} |  | ||||||
|     public int WareHouseMinWeight {get; set;} |  | ||||||
|     public string? WareHouseAddress { get; set; } |  | ||||||
|     public int WareHouseZipCode { get; set; } |  | ||||||
|     public string? WareHouseCity { get; set; } |  | ||||||
|      |  | ||||||
|     public int ProductId { get; set; } |  | ||||||
|     public int ProductReferences { get; set; } |  | ||||||
|     public string? ProductName { get; set; } |  | ||||||
|     public decimal ProductDuration {get; set;}  |  | ||||||
|     public decimal ProductCaliber { get; set; } |  | ||||||
|     public int ProductApprovalNumber { get; set; } |  | ||||||
|     public decimal ProductWeight { get; set; } |  | ||||||
|     public decimal ProductNec { get; set; } |  | ||||||
|     public string? ProductImage { get; set; } |  | ||||||
|     public string? ProductLink { get; set; } |  | ||||||
|     public int ProductMinimalQuantity { get; set; } |  | ||||||
| } |  | ||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | namespace PyroFetes.DTO.WareHouseProduct.Response; | ||||||
|  |  | ||||||
|  | public class GetTotalQuantityDto | ||||||
|  | { | ||||||
|  |     public int ProductId { get; set; } | ||||||
|  |     public int TotalQuantity { get; set; } | ||||||
|  | } | ||||||
| @@ -2,27 +2,7 @@ namespace PyroFetes.DTO.WareHouseProduct.Response; | |||||||
|  |  | ||||||
| public class GetWareHouseProductDto | public class GetWareHouseProductDto | ||||||
| { | { | ||||||
|     public int Id { get; set; } |  | ||||||
|     public int Quantity { get; set; } |     public int Quantity { get; set; } | ||||||
|      |  | ||||||
|     public int WareHouseId { get; set; } |     public int WareHouseId { get; set; } | ||||||
|     public string? WareHouseName {get; set;} |  | ||||||
|     public int WareHouseMaxWeight {get; set;} |  | ||||||
|     public int WareHouseCurrent {get; set;} |  | ||||||
|     public int WareHouseMinWeight {get; set;} |  | ||||||
|     public string? WareHouseAddress { get; set; } |  | ||||||
|     public int WareHouseZipCode { get; set; } |  | ||||||
|     public string? WareHouseCity { get; set; } |  | ||||||
|      |  | ||||||
|     public int ProductId { get; set; } |     public int ProductId { get; set; } | ||||||
|     public int ProductReferences { get; set; } |  | ||||||
|     public string? ProductName { get; set; } |  | ||||||
|     public decimal ProductDuration {get; set;}  |  | ||||||
|     public decimal ProductCaliber { get; set; } |  | ||||||
|     public int ProductApprovalNumber { get; set; } |  | ||||||
|     public decimal ProductWeight { get; set; } |  | ||||||
|     public decimal ProductNec { get; set; } |  | ||||||
|     public string? ProductImage { get; set; } |  | ||||||
|     public string? ProductLink { get; set; } |  | ||||||
|     public int ProductMinimalQuantity { get; set; } |  | ||||||
| } | } | ||||||
| @@ -12,7 +12,7 @@ public class DeletePurchaseOrderEndpoint(PyroFetesDbContext database) : Endpoint | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Delete("/api/purchaseOrders/{Id}", x => new {x.Id}); |         Delete("/api/purchaseOrders/{@Id}", x => new {x.Id}); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ public class PatchPurchaseOrderPurchaseConditionsEndpoint(PyroFetesDbContext dat | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Patch("/api/purchaseOrders/{Id}/PurchaseConditions", x => new { x.Id }); |         Patch("/api/purchaseOrders/{@Id}/PurchaseConditions", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ public class DeletePurchaseOrderEndpoint(PyroFetesDbContext database) : Endpoint | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Delete("/api/purchaseProducts/{ProductId}/{PurchaseOrderId}", x => new {x.ProductId, x.PurchaseOrderId}); |         Delete("/api/purchaseProducts/{@ProductId}/{@PurchaseOrderId}", x => new {x.ProductId, x.PurchaseOrderId}); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ public class PatchPurchaseProductQuantityEndpoint(PyroFetesDbContext database) : | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Patch("/api/purchaseProducts/{ProductId}/{PurchaseOrderId}/Quantity", x => new { x.ProductId, x.PurchaseOrderId }); |         Patch("/api/purchaseProducts/{@ProductId}/{@PurchaseOrderId}/Quantity", x => new { x.ProductId, x.PurchaseOrderId }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ public class DeleteQuotationEndpoint(PyroFetesDbContext database) : Endpoint<Del | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Delete("/api/quotations/{Id}", x => new {x.Id}); |         Delete("/api/quotations/{@Id}", x => new {x.Id}); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ public class PatchQuotationConditionsSaleEndpoint(PyroFetesDbContext database) : | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Patch("/api/quotations/{Id}/ConditionsSale", x => new { x.Id }); |         Patch("/api/quotations/{@Id}/ConditionsSale", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,11 +1,9 @@ | |||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| using PyroFetes.DTO.PurchaseProduct.Request; |  | ||||||
| using PyroFetes.DTO.PurchaseProduct.Response; |  | ||||||
| using PyroFetes.DTO.QuotationProduct.Request; | using PyroFetes.DTO.QuotationProduct.Request; | ||||||
| using PyroFetes.DTO.QuotationProduct.Response; | using PyroFetes.DTO.QuotationProduct.Response; | ||||||
| 
 | 
 | ||||||
| namespace PyroFetes.Endpoints.QuoationProduct; | namespace PyroFetes.Endpoints.QuotationProduct; | ||||||
| 
 | 
 | ||||||
| public class CreateQuotationProductEndpoint(PyroFetesDbContext database) : Endpoint<CreateQuotationProductDto, GetQuotationProductDto> | public class CreateQuotationProductEndpoint(PyroFetesDbContext database) : Endpoint<CreateQuotationProductDto, GetQuotationProductDto> | ||||||
| { | { | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| 
 | 
 | ||||||
| namespace PyroFetes.Endpoints.QuoationProduct; | namespace PyroFetes.Endpoints.QuotationProduct; | ||||||
| 
 | 
 | ||||||
| public class DeleteQuotationProductRequest | public class DeleteQuotationProductRequest | ||||||
| { | { | ||||||
| @@ -13,7 +13,7 @@ public class DeleteQuotationProductEndpoint(PyroFetesDbContext database) : Endpo | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Delete("/api/quotationProduct/{ProductId}/{QuotationId}", x => new {x.ProductId, x.QuotationId}); |         Delete("/api/quotationProduct/{@ProductId}/{@QuotationId}", x => new {x.ProductId, x.QuotationId}); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @@ -3,13 +3,13 @@ using Microsoft.EntityFrameworkCore; | |||||||
| using PyroFetes.DTO.QuotationProduct.Request; | using PyroFetes.DTO.QuotationProduct.Request; | ||||||
| using PyroFetes.DTO.QuotationProduct.Response; | using PyroFetes.DTO.QuotationProduct.Response; | ||||||
| 
 | 
 | ||||||
| namespace PyroFetes.Endpoints.QuoationProduct; | namespace PyroFetes.Endpoints.QuotationProduct; | ||||||
| 
 | 
 | ||||||
| public class PatchQuotationProductQuantityEndpoint(PyroFetesDbContext database) : Endpoint<PatchQuotationProductQuantityDto, GetQuotationProductDto> | public class PatchQuotationProductQuantityEndpoint(PyroFetesDbContext database) : Endpoint<PatchQuotationProductQuantityDto, GetQuotationProductDto> | ||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Patch("/api/quotationProduct/{ProductId}/{QuotationId}/Quantity", x => new { x.ProductId, x.QuotationId }); |         Patch("/api/quotationProduct/{@ProductId}/{@QuotationId}/Quantity", x => new { x.ProductId, x.QuotationId }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @@ -0,0 +1,42 @@ | |||||||
|  | using FastEndpoints; | ||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using PyroFetes.DTO.WareHouseProduct.Response; | ||||||
|  |  | ||||||
|  | namespace PyroFetes.Endpoints.WareHouseProduct; | ||||||
|  |  | ||||||
|  | public class GetTotalQuantityRequest | ||||||
|  | { | ||||||
|  |     public int ProductId { get; set; } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | public class GetTotalQuantityEndpoint(PyroFetesDbContext database) : Endpoint<GetTotalQuantityRequest, GetTotalQuantityDto> | ||||||
|  | { | ||||||
|  |     public override void Configure() | ||||||
|  |     { | ||||||
|  |         Get("/api/wareHouseProduct/{@ProductId}", x => new { x.ProductId }); | ||||||
|  |         AllowAnonymous(); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     public override async Task HandleAsync(GetTotalQuantityRequest req, CancellationToken ct) | ||||||
|  |     { | ||||||
|  |         var exists = await database.WarehouseProducts | ||||||
|  |             .AnyAsync(wp => wp.ProductId == req.ProductId, ct); | ||||||
|  |  | ||||||
|  |         if (!exists) | ||||||
|  |         { | ||||||
|  |             await Send.NotFoundAsync(ct); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         var totalQuantity = await database.WarehouseProducts | ||||||
|  |             .Where(wp => wp.ProductId == req.ProductId) | ||||||
|  |             .SumAsync(wp => wp.Quantity, ct); | ||||||
|  |  | ||||||
|  |         GetTotalQuantityDto responseDto = new() | ||||||
|  |         { | ||||||
|  |             ProductId = req.ProductId, | ||||||
|  |             TotalQuantity = totalQuantity | ||||||
|  |         }; | ||||||
|  |         await Send.OkAsync(responseDto, ct); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,38 @@ | |||||||
|  | using FastEndpoints; | ||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using PyroFetes.DTO.QuotationProduct.Request; | ||||||
|  | using PyroFetes.DTO.QuotationProduct.Response; | ||||||
|  | using PyroFetes.DTO.WareHouseProduct.Request; | ||||||
|  | using PyroFetes.DTO.WareHouseProduct.Response; | ||||||
|  |  | ||||||
|  | namespace PyroFetes.Endpoints.WareHouseProduct; | ||||||
|  |  | ||||||
|  | public class PatchWareHouseProductQuantityEndpoint(PyroFetesDbContext database) : Endpoint<PatchWareHouseProductQuantityDto, GetWareHouseProductDto> | ||||||
|  | { | ||||||
|  |     public override void Configure() | ||||||
|  |     { | ||||||
|  |         Patch("/api/wareHouseProduct/{@ProductId}/{@WareHouseId}/Quantity", x => new { x.ProductId, x.WareHouseId }); | ||||||
|  |         AllowAnonymous(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public override async Task HandleAsync(PatchWareHouseProductQuantityDto req, CancellationToken ct) | ||||||
|  |     { | ||||||
|  |         var wareHouseProduct = await database.WarehouseProducts.SingleOrDefaultAsync(wp => wp.ProductId == req.ProductId && wp.WarehouseId == req.WareHouseId, ct); | ||||||
|  |         if (wareHouseProduct == null) | ||||||
|  |         { | ||||||
|  |             await Send.NotFoundAsync(ct); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         wareHouseProduct.Quantity = req.Quantity; | ||||||
|  |         await database.SaveChangesAsync(ct); | ||||||
|  |  | ||||||
|  |         GetWareHouseProductDto responseDto = new() | ||||||
|  |         { | ||||||
|  |             ProductId = wareHouseProduct.ProductId, | ||||||
|  |             WareHouseId = wareHouseProduct.WarehouseId, | ||||||
|  |             Quantity = wareHouseProduct.Quantity | ||||||
|  |         }; | ||||||
|  |         await Send.OkAsync(responseDto, ct); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,18 +1,26 @@ | |||||||
| var builder = WebApplication.CreateBuilder(args); | using PyroFetes; | ||||||
|  | using FastEndpoints; | ||||||
|  | using FastEndpoints.Swagger; | ||||||
|  | using FastEndpoints.Security; | ||||||
|  |  | ||||||
| // Add services to the container. | WebApplicationBuilder builder = WebApplication.CreateBuilder(args); | ||||||
| // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle |  | ||||||
| builder.Services.AddEndpointsApiExplorer(); |  | ||||||
| builder.Services.AddSwaggerGen(); |  | ||||||
|  |  | ||||||
| var app = builder.Build(); | // On ajoute ici FastEndpoints, un framework REPR et Swagger aux services disponibles dans le projet | ||||||
|  | builder.Services | ||||||
|  |     .AddAuthenticationJwtBearer(s => s.SigningKey = "ThisIsASuperSecretJwtKeyThatIsAtLeast32CharsLong") | ||||||
|  |     .AddAuthorization() | ||||||
|  |     .AddFastEndpoints() | ||||||
|  |     .SwaggerDocument(); | ||||||
|  |  | ||||||
| // Configure the HTTP request pipeline. | // On ajoute ici la configuration de la base de données | ||||||
| if (app.Environment.IsDevelopment()) | builder.Services.AddDbContext<PyroFetesDbContext>(); | ||||||
| { |  | ||||||
|     app.UseSwagger(); | // On construit l'application en lui donnant vie | ||||||
|     app.UseSwaggerUI(); | WebApplication app = builder.Build(); | ||||||
| } | app.UseAuthentication() | ||||||
|  |     .UseAuthorization() | ||||||
|  |     .UseFastEndpoints() | ||||||
|  |     .UseSwaggerGen(); | ||||||
|  |  | ||||||
| app.UseHttpsRedirection(); | app.UseHttpsRedirection(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,6 +9,8 @@ | |||||||
|     <ItemGroup> |     <ItemGroup> | ||||||
|         <PackageReference Include="BCrypt.Net-Next" Version="4.0.3" /> |         <PackageReference Include="BCrypt.Net-Next" Version="4.0.3" /> | ||||||
|         <PackageReference Include="FastEndpoints" Version="7.0.1" /> |         <PackageReference Include="FastEndpoints" Version="7.0.1" /> | ||||||
|  |         <PackageReference Include="FastEndpoints.Security" Version="7.0.1" /> | ||||||
|  |         <PackageReference Include="FastEndpoints.Swagger" Version="7.0.1" /> | ||||||
|         <PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.19"/> |         <PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.19"/> | ||||||
|         <PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.20" /> |         <PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.20" /> | ||||||
|         <PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="8.0.20"> |         <PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="8.0.20"> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user