forked from sanchezvem/PyroFetes
		
	Compare commits
	
		
			23 Commits
		
	
	
		
			f155d03559
			...
			develop
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4c0e7df9de | |||
| 5506eab8ff | |||
| 15545980af | |||
| dda2240e86 | |||
| a014c6c9f7 | |||
| 2112605cf3 | |||
| 90d685d42c | |||
| 2bcca6f856 | |||
| 6d564c89ff | |||
| bad259e9f5 | |||
| 32dee6eb18 | |||
| b3347fe163 | |||
| 0e74cb40f5 | |||
| 91b4aca2fa | |||
| 1734ec0219 | |||
| 7a8daa6ab8 | |||
| 8f4171a045 | |||
| 8a8a47c99c | |||
| bb5dd63da2 | |||
| c5805d979b | |||
| 44da6ed371 | |||
| 08bf910437 | |||
| d1fa3aca68 | 
| @@ -1,7 +1,9 @@ | ||||
| namespace API.DTO.Brand.Request; | ||||
|  | ||||
| public class CreateBrandDto | ||||
| namespace PyroFetes.DTO.Brand.Request | ||||
| { | ||||
|     public string? Name { get; set; } | ||||
|      | ||||
|     // DTO pour créer une nouvelle marque | ||||
|     public class CreateBrandDto | ||||
|     { | ||||
|         // Nom de la marque | ||||
|         public string? Name { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,8 +1,12 @@ | ||||
| namespace API.DTO.Brand.Request; | ||||
|  | ||||
| public class UpdateBrandDto | ||||
| namespace PyroFetes.DTO.Brand.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Name { get; set; } | ||||
|      | ||||
|     // DTO pour mettre à jour une marque existante | ||||
|     public class UpdateBrandDto | ||||
|     { | ||||
|         // Identifiant de la marque à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nouveau nom de la marque | ||||
|         public string? Name { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,8 +1,12 @@ | ||||
| namespace API.DTO.Brand.Response; | ||||
|  | ||||
| public class GetBrandDto | ||||
| namespace API.DTO.Brand.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Name { get; set; } | ||||
|      | ||||
|     // DTO pour récupérer les informations d'une marque | ||||
|     public class GetBrandDto | ||||
|     { | ||||
|         // Identifiant de la marque | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom de la marque | ||||
|         public string? Name { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,11 @@ | ||||
| namespace API.DTO.Classification.Request; | ||||
|  | ||||
| public class CreateClassificationDto | ||||
| // Définition de l'espace de noms pour les DTO liés à la création de classifications | ||||
| namespace API.DTO.Classification.Request | ||||
| { | ||||
|     public string? Label { get; set; } | ||||
|      | ||||
|     // DTO (Data Transfer Object) utilisé pour créer une nouvelle classification | ||||
|     public class CreateClassificationDto | ||||
|     { | ||||
|         // Propriété représentant le nom ou le label de la classification | ||||
|         // Le type "string?" signifie que cette valeur peut être null | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,8 +1,15 @@ | ||||
| namespace API.DTO.Classification.Request; | ||||
|  | ||||
| public class UpdateClassificationDto | ||||
| // Définition de l'espace de noms pour les DTO liés à la mise à jour de classifications | ||||
| namespace API.DTO.Classification.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|      | ||||
|     // DTO (Data Transfer Object) utilisé pour mettre à jour une classification existante | ||||
|     public class UpdateClassificationDto | ||||
|     { | ||||
|         // Propriété représentant l'ID unique de la classification à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Propriété représentant le nouveau nom ou label de la classification | ||||
|         // Le type "string?" signifie que cette valeur peut être null | ||||
|         // Si null, le label ne sera pas modifié | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,8 +1,14 @@ | ||||
| namespace API.DTO.Classification.Response; | ||||
|  | ||||
| public class GetClassificationDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les réponses liées aux classifications | ||||
| namespace API.DTO.Classification.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|      | ||||
|     // DTO (Data Transfer Object) utilisé pour renvoyer les informations d'une classification | ||||
|     public class GetClassificationDto | ||||
|     { | ||||
|         // Propriété représentant l'ID unique de la classification | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Propriété représentant le nom ou label de la classification | ||||
|         // Le type "string?" signifie que cette valeur peut être null si la classification n'a pas de label | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,6 +1,11 @@ | ||||
| namespace API.DTO.Color.Request; | ||||
|  | ||||
| public class CreateColorDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux couleurs | ||||
| namespace API.DTO.Color.Request | ||||
| { | ||||
|     public string? Label { get; set; } | ||||
|     // DTO utilisé pour créer une nouvelle couleur | ||||
|     public class CreateColorDto | ||||
|     { | ||||
|         // Propriété représentant le nom ou label de la couleur à créer | ||||
|         // Le type "string?" signifie que cette valeur peut être null si le label n'est pas fourni | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,14 @@ | ||||
| namespace API.DTO.Color.Request; | ||||
|  | ||||
| public class UpdateColorDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux couleurs | ||||
| namespace API.DTO.Color.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     // DTO utilisé pour mettre à jour une couleur existante | ||||
|     public class UpdateColorDto | ||||
|     { | ||||
|         // Identifiant unique de la couleur à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nouveau nom ou label de la couleur | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucun changement n'est fourni | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,14 @@ | ||||
| namespace API.DTO.Color.Response; | ||||
|  | ||||
| public class GetColorDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les réponses liées aux couleurs | ||||
| namespace API.DTO.Color.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     // DTO utilisé pour renvoyer les informations d'une couleur | ||||
|     public class GetColorDto | ||||
|     { | ||||
|         // Identifiant unique de la couleur | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom ou label de la couleur | ||||
|         // Le type "string?" signifie que cette valeur peut être null si le label n'est pas défini | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,6 +1,11 @@ | ||||
| namespace API.DTO.Effect.Request; | ||||
|  | ||||
| public class CreateEffectDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux effets | ||||
| namespace API.DTO.Effect.Request | ||||
| { | ||||
|     public string? Label { get; set; } | ||||
|     // DTO utilisé pour créer un nouvel effet | ||||
|     public class CreateEffectDto | ||||
|     { | ||||
|         // Nom ou label de l'effet | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucun label n'est fourni | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,14 @@ | ||||
| namespace API.DTO.Effect.Request; | ||||
|  | ||||
| public class UpdateEffectDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux effets | ||||
| namespace API.DTO.Effect.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     // DTO utilisé pour mettre à jour un effet existant | ||||
|     public class UpdateEffectDto | ||||
|     { | ||||
|         // Identifiant unique de l'effet à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nouveau nom ou label de l'effet | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucun label n'est fourni | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,14 @@ | ||||
| namespace API.DTO.Effect.Response; | ||||
|  | ||||
| public class GetEffectDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les réponses liées aux effets | ||||
| namespace API.DTO.Effect.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     // DTO utilisé pour renvoyer les informations d'un effet | ||||
|     public class GetEffectDto | ||||
|     { | ||||
|         // Identifiant unique de l'effet | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom ou label de l'effet | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucune valeur n'est disponible | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										7
									
								
								PyroFetes/DTO/Login/Request/ConnectLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								PyroFetes/DTO/Login/Request/ConnectLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| namespace PyroFetes.DTO.Login.Request; | ||||
|  | ||||
| public class ConnectLoginDto | ||||
| { | ||||
|     public string? Username { get; set; } | ||||
|     public string? Password { get; set; } | ||||
| } | ||||
							
								
								
									
										8
									
								
								PyroFetes/DTO/Login/Request/CreateLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								PyroFetes/DTO/Login/Request/CreateLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| namespace PyroFetes.DTO.Login.Request; | ||||
|  | ||||
| public class CreateLoginDto | ||||
| { | ||||
|     public string? Username { get; set; } | ||||
|     public string? FullName { get; set; } | ||||
|     public string? Password { get; set; } | ||||
| } | ||||
							
								
								
									
										9
									
								
								PyroFetes/DTO/Login/Request/UpdateLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								PyroFetes/DTO/Login/Request/UpdateLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| namespace PyroFetes.DTO.Login.Request; | ||||
|  | ||||
| public class UpdateLoginDto | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Username { get; set; } | ||||
|     public string? FullName { get; set; } | ||||
|     public string? Password { get; set; } | ||||
| } | ||||
							
								
								
									
										6
									
								
								PyroFetes/DTO/Login/Response/GetLoginConnectDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								PyroFetes/DTO/Login/Response/GetLoginConnectDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| namespace PyroFetes.DTO.Login.Response; | ||||
|  | ||||
| public class GetLoginConnectDto | ||||
| { | ||||
|     public string? Token { get; set; } | ||||
| } | ||||
							
								
								
									
										10
									
								
								PyroFetes/DTO/Login/Response/GetLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								PyroFetes/DTO/Login/Response/GetLoginDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| namespace PyroFetes.DTO.Login.Response; | ||||
|  | ||||
| public class GetLoginDto | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Username { get; set; } | ||||
|     public string? FullName { get; set; } | ||||
|     public string? Password { get; set; } | ||||
|     public string? Salt { get; set; } | ||||
| } | ||||
| @@ -1,9 +1,17 @@ | ||||
| namespace API.DTO.Material.Request; | ||||
|  | ||||
| public class CreateMaterialDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux matériaux | ||||
| namespace API.DTO.Material.Request | ||||
| { | ||||
|     public string? Label { get; set; } | ||||
|     public int Quantity { get; set; } | ||||
|     public int WarehouseId {get; set;} | ||||
|     // DTO utilisé pour créer un nouveau matériau | ||||
|     public class CreateMaterialDto | ||||
|     { | ||||
|         // Nom ou label du matériau | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucune valeur n'est fournie | ||||
|         public string? Label { get; set; } | ||||
|  | ||||
|         // Quantité du matériau à créer | ||||
|         public int Quantity { get; set; } | ||||
|  | ||||
|         // Identifiant de l'entrepôt dans lequel le matériau sera stocké | ||||
|         public int WarehouseId { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,10 +1,20 @@ | ||||
| namespace API.DTO.Material.Request; | ||||
|  | ||||
| public class UpdateMaterialDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux matériaux | ||||
| namespace API.DTO.Material.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     public int Quantity { get; set; } | ||||
|     public int WarehouseId {get; set;} | ||||
|     // DTO utilisé pour mettre à jour un matériau existant | ||||
|     public class UpdateMaterialDto | ||||
|     { | ||||
|         // Identifiant unique du matériau à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom ou label du matériau | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucune valeur n'est fournie | ||||
|         public string? Label { get; set; } | ||||
|  | ||||
|         // Quantité mise à jour du matériau | ||||
|         public int Quantity { get; set; } | ||||
|  | ||||
|         // Identifiant de l'entrepôt associé au matériau | ||||
|         public int WarehouseId { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,10 +1,20 @@ | ||||
| namespace API.DTO.Material.Response; | ||||
|  | ||||
| public class GetMaterialDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les réponses liées aux matériaux | ||||
| namespace API.DTO.Material.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     public int Quantity { get; set; } | ||||
|     public int WarehouseId {get; set;} | ||||
|     // DTO utilisé pour renvoyer les informations d'un matériau | ||||
|     public class GetMaterialDto | ||||
|     { | ||||
|         // Identifiant unique du matériau | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom ou label du matériau | ||||
|         // Le type "string?" signifie que cette valeur peut être null si aucune valeur n'est définie | ||||
|         public string? Label { get; set; } | ||||
|  | ||||
|         // Quantité disponible du matériau | ||||
|         public int Quantity { get; set; } | ||||
|  | ||||
|         // Identifiant de l'entrepôt auquel le matériau est associé | ||||
|         public int WarehouseId { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,10 +1,19 @@ | ||||
| namespace API.DTO.Movement.Request; | ||||
|  | ||||
| public class CreateMovementDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux mouvements | ||||
| namespace API.DTO.Movement.Request | ||||
| { | ||||
|     public DateTime Date  { get; set; } | ||||
|     public DateTime Start {get; set;} | ||||
|     public DateTime Arrival {get; set;} | ||||
|     public int Quantity {get; set;} | ||||
|      | ||||
|     // DTO utilisé pour créer un nouveau mouvement | ||||
|     public class CreateMovementDto | ||||
|     { | ||||
|         // Date à laquelle le mouvement est enregistré | ||||
|         public DateTime Date  { get; set; } | ||||
|  | ||||
|         // Date et heure de début du mouvement | ||||
|         public DateTime Start { get; set; } | ||||
|  | ||||
|         // Date et heure d'arrivée prévue du mouvement | ||||
|         public DateTime Arrival { get; set; } | ||||
|  | ||||
|         // Quantité de matériaux ou objets impliqués dans le mouvement | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,11 +1,22 @@ | ||||
| namespace API.DTO.Movement.Request; | ||||
|  | ||||
| public class UpdateMovementDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les requêtes liées aux mouvements | ||||
| namespace API.DTO.Movement.Request | ||||
| { | ||||
|     public int  Id  { get; set; } | ||||
|     public DateTime Date  { get; set; } | ||||
|     public DateTime Start {get; set;} | ||||
|     public DateTime Arrival {get; set;} | ||||
|     public int Quantity {get; set;} | ||||
|      | ||||
|     // DTO utilisé pour mettre à jour un mouvement existant | ||||
|     public class UpdateMovementDto | ||||
|     { | ||||
|         // ID unique du mouvement à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Date à laquelle le mouvement est enregistré | ||||
|         public DateTime Date { get; set; } | ||||
|  | ||||
|         // Date et heure de début du mouvement | ||||
|         public DateTime Start { get; set; } | ||||
|  | ||||
|         // Date et heure d'arrivée prévue du mouvement | ||||
|         public DateTime Arrival { get; set; } | ||||
|  | ||||
|         // Quantité de matériaux ou objets impliqués dans le mouvement | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,11 +1,22 @@ | ||||
| namespace API.DTO.Movement.Response; | ||||
|  | ||||
| public class GetMovementDto | ||||
| // Définition de l'espace de noms pour les DTO utilisés dans les réponses liées aux mouvements | ||||
| namespace API.DTO.Movement.Response | ||||
| { | ||||
|     public int  Id  { get; set; } | ||||
|     public DateTime Date  { get; set; } | ||||
|     public DateTime Start {get; set;} | ||||
|     public DateTime Arrival {get; set;} | ||||
|     public int Quantity {get; set;} | ||||
|      | ||||
|     // DTO utilisé pour renvoyer les informations d'un mouvement | ||||
|     public class GetMovementDto | ||||
|     { | ||||
|         // ID unique du mouvement | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Date à laquelle le mouvement est enregistré | ||||
|         public DateTime Date { get; set; } | ||||
|  | ||||
|         // Date et heure de début du mouvement | ||||
|         public DateTime Start { get; set; } | ||||
|  | ||||
|         // Date et heure d'arrivée prévue du mouvement | ||||
|         public DateTime Arrival { get; set; } | ||||
|  | ||||
|         // Quantité de matériaux ou objets impliqués dans le mouvement | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,21 +1,50 @@ | ||||
| using PyroFetes.Models; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
|  | ||||
| namespace PyroFetes.DTO.Product.Request; | ||||
|  | ||||
| public class CreateProductDto | ||||
| namespace PyroFetes.DTO.Product.Request | ||||
| { | ||||
|     public int References { get; set; } | ||||
|     public string? Name { get; set; } | ||||
|     public decimal Duration { get; set; } | ||||
|     public decimal Caliber { get; set; } | ||||
|     public int ApprovalNumber { get; set; } | ||||
|     public decimal Weight { get; set; } | ||||
|     public decimal Nec { get; set; } | ||||
|     public decimal SellingPrice {get; set;} | ||||
|     public string? Image { get; set; } | ||||
|     public string? Link { get; set; } | ||||
|      | ||||
|     public int ClassificationId { get; set;} | ||||
|     public int ProductCategoryId { get; set; } | ||||
|      | ||||
|     // DTO utilisé lors de la création d’un produit | ||||
|     public class CreateProductDto | ||||
|     { | ||||
|         // Référence interne du produit | ||||
|         public int References { get; set; } | ||||
|  | ||||
|         // Nom du produit | ||||
|         public string? Name { get; set; } | ||||
|  | ||||
|         // Durée de l’effet du produit | ||||
|         public decimal Duration { get; set; } | ||||
|  | ||||
|         // Calibre du produit | ||||
|         public decimal Caliber { get; set; } | ||||
|  | ||||
|         // Numéro d’homologation | ||||
|         public int ApprovalNumber { get; set; } | ||||
|  | ||||
|         // Poids du produit | ||||
|         public decimal Weight { get; set; } | ||||
|  | ||||
|         // Matière active (NEC) | ||||
|         public decimal Nec { get; set; } | ||||
|  | ||||
|         // Prix de vente du produit | ||||
|         public decimal SellingPrice { get; set; } | ||||
|  | ||||
|         // Image associée au produit (URL ou chemin) | ||||
|         public string? Image { get; set; } | ||||
|  | ||||
|         // Lien vers une ressource externe (vidéo, fiche, etc.) | ||||
|         public string? Link { get; set; } | ||||
|  | ||||
|         // Identifiant de la classification du produit | ||||
|         public int ClassificationId { get; set; } | ||||
|  | ||||
|         // Identifiant de la catégorie du produit | ||||
|         public int ProductCategoryId { get; set; } | ||||
|  | ||||
|         // Liste des fournisseurs liés au produit venant du DTO ProductSupplierPriceDto | ||||
|         public List<ProductSupplierPriceDto>? Suppliers { get; set; } | ||||
|  | ||||
|         // Liste des entrepôts liés au produit venant du DTO CreateProductWarehouseDto | ||||
|         public List<CreateProductWarehouseDto>? Warehouses { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,20 +1,53 @@ | ||||
| using PyroFetes.Models; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
|  | ||||
| namespace PyroFetes.DTO.Product.Request; | ||||
|  | ||||
| public class UpdateProductDto | ||||
| namespace PyroFetes.DTO.Product.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public int Reference { get; set; } | ||||
|     public string? Name { get; set; } | ||||
|     public decimal Duration { get; set; } | ||||
|     public decimal Caliber { get; set; } | ||||
|     public int ApprovalNumber { get; set; } | ||||
|     public decimal Weight { get; set; } | ||||
|     public decimal Nec { get; set; } | ||||
|     public decimal SellingPrice {get; set;} | ||||
|     public string? Image { get; set; } | ||||
|     public string? Link { get; set; } | ||||
|     public int ClassificationId { get; set;} | ||||
|     public int ProductCategoryId { get; set; } | ||||
|     // DTO utilisé pour la mise à jour d’un produit existant | ||||
|     public class UpdateProductDto | ||||
|     { | ||||
|         // Identifiant unique du produit à modifier | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Référence interne du produit | ||||
|         public int References { get; set; } | ||||
|  | ||||
|         // Nom du produit | ||||
|         public string? Name { get; set; } | ||||
|  | ||||
|         // Durée de l’effet du produit | ||||
|         public decimal Duration { get; set; } | ||||
|  | ||||
|         // Calibre du produit | ||||
|         public decimal Caliber { get; set; } | ||||
|  | ||||
|         // Numéro d’homologation | ||||
|         public int ApprovalNumber { get; set; } | ||||
|  | ||||
|         // Poids du produit | ||||
|         public decimal Weight { get; set; } | ||||
|  | ||||
|         // Matière active (NEC) | ||||
|         public decimal Nec { get; set; } | ||||
|  | ||||
|         // Prix de vente du produit | ||||
|         public decimal SellingPrice { get; set; } | ||||
|  | ||||
|         // Image associée au produit (URL ou chemin) | ||||
|         public string? Image { get; set; } | ||||
|  | ||||
|         // Lien vers une ressource externe (fiche, vidéo, etc.) | ||||
|         public string? Link { get; set; } | ||||
|  | ||||
|         // Identifiant de la classification du produit | ||||
|         public int ClassificationId { get; set; } | ||||
|  | ||||
|         // Identifiant de la catégorie du produit | ||||
|         public int ProductCategoryId { get; set; } | ||||
|  | ||||
|         // Liste des fournisseurs associés venant du DTO ProductSupplierPriceDto | ||||
|         public List<ProductSupplierPriceDto> Suppliers { get; set; } = new(); | ||||
|  | ||||
|         // Liste des entrepôts associés venant du DTO UpdateProductWarehouseDto | ||||
|         public List<UpdateProductWarehouseDto> Warehouses { get; set; } = new(); | ||||
|     } | ||||
| } | ||||
| @@ -1,23 +1,54 @@ | ||||
| using PyroFetes.Models; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
|  | ||||
| namespace PyroFetes.DTO.Product.Response; | ||||
|  | ||||
| public class GetProductDto | ||||
| namespace PyroFetes.DTO.Product.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public int Reference { get; set; } | ||||
|     public string? Name { get; set; } | ||||
|     public decimal Duration { get; set; } | ||||
|     public decimal Caliber { get; set; } | ||||
|     public int ApprovalNumber { get; set; } | ||||
|     public decimal Weight { get; set; } | ||||
|     public decimal Nec { get; set; } | ||||
|     public decimal SellingPrice {get; set;} | ||||
|     public string? Image { get; set; } | ||||
|     public string? Link { get; set; } | ||||
|     public int ClassificationId { get; set;} | ||||
|     public string? ClassificationLabel { get; set; } | ||||
|     public int ProductCategoryId { get; set; } | ||||
|     public string? ProductCategoryLabel { get; set; } | ||||
|   | ||||
|     // DTO utilisé pour renvoyer les informations complètes d’un produit | ||||
|     public class GetProductDto | ||||
|     { | ||||
|         // Identifiant unique du produit | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Référence interne du produit | ||||
|         public int Reference { get; set; } | ||||
|  | ||||
|         // Nom du produit | ||||
|         public string? Name { get; set; } | ||||
|  | ||||
|         // Durée de l’effet du produit | ||||
|         public decimal Duration { get; set; } | ||||
|  | ||||
|         // Calibre du produit | ||||
|         public decimal Caliber { get; set; } | ||||
|  | ||||
|         // Numéro d’homologation | ||||
|         public int ApprovalNumber { get; set; } | ||||
|  | ||||
|         // Poids du produit | ||||
|         public decimal Weight { get; set; } | ||||
|  | ||||
|         // Matière active (NEC) | ||||
|         public decimal Nec { get; set; } | ||||
|  | ||||
|         // Prix de vente du produit | ||||
|         public decimal SellingPrice { get; set; } | ||||
|  | ||||
|         // Image du produit (URL ou chemin) | ||||
|         public string? Image { get; set; } | ||||
|  | ||||
|         // Lien externe vers plus d’informations (fiche, vidéo, etc.) | ||||
|         public string? Link { get; set; } | ||||
|  | ||||
|         // Identifiant de la classification du produit | ||||
|         public int ClassificationId { get; set; } | ||||
|  | ||||
|         // Identifiant de la catégorie du produit | ||||
|         public int ProductCategoryId { get; set; } | ||||
|  | ||||
|         // Fournisseurs liés venant du DTO ProductSupplierPriceDto | ||||
|         public List<ProductSupplierPriceDto> Suppliers { get; set; } = new(); | ||||
|  | ||||
|         // Entrepôts liés venant du DTO ProductWarehouseDto | ||||
|         public List<GetProductWarehouseDto> Warehouses { get; set; } = new(); | ||||
|     } | ||||
| } | ||||
| @@ -1,6 +1,9 @@ | ||||
| namespace API.DTO.ProductCategory.Request; | ||||
|  | ||||
| public class CreateProductCategoryDto | ||||
| namespace API.DTO.ProductCategory.Request | ||||
| { | ||||
|     public string? Label { get; set; } | ||||
|     // DTO pour créer une catégorie de produit | ||||
|     public class CreateProductCategoryDto | ||||
|     { | ||||
|         // Nom de la catégorie | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,7 +1,12 @@ | ||||
| namespace API.DTO.ProductCategory.Request; | ||||
|  | ||||
| public class UpdateProductCategoryDto | ||||
| namespace API.DTO.ProductCategory.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|     // DTO pour mettre à jour une catégorie de produit | ||||
|     public class UpdateProductCategoryDto | ||||
|     { | ||||
|         // Identifiant de la catégorie | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom de la catégorie | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,8 +1,12 @@ | ||||
| namespace API.DTO.ProductCategory.Response; | ||||
|  | ||||
| public class GetProductCategoryDto | ||||
| namespace API.DTO.ProductCategory.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string? Label { get; set; } | ||||
|      | ||||
|     // DTO pour récupérer une catégorie de produit | ||||
|     public class GetProductCategoryDto | ||||
|     { | ||||
|         // Identifiant de la catégorie | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom de la catégorie | ||||
|         public string? Label { get; set; } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										7
									
								
								PyroFetes/DTO/ProductColor/Request/ProductColorDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								PyroFetes/DTO/ProductColor/Request/ProductColorDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| namespace PyroFetes.DTO.ProductColor.Request; | ||||
| // DTO utilisé pour créer ou mettre à jour la relation Product <-> Color | ||||
| public class ProductColorDto | ||||
| { | ||||
|     public int ProductId { get; set; }       // Id du produit (pour update) | ||||
|     public int ColorId { get; set; }      // Id de la couleur | ||||
| } | ||||
							
								
								
									
										11
									
								
								PyroFetes/DTO/ProductColor/Response/GetProductColorDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								PyroFetes/DTO/ProductColor/Response/GetProductColorDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| namespace PyroFetes.DTO.ProductColor.Response; | ||||
| // DTO utilisé pour renvoyer les informations d’un produit lié à une couleur | ||||
|  | ||||
| public class GetProductColorDto | ||||
| { | ||||
|     // Identifiant du produit concerné | ||||
|     public int ProductId { get; set; } | ||||
|  | ||||
|     // Identifiant de la couleur | ||||
|     public int ColorId { get; set; } | ||||
| } | ||||
							
								
								
									
										8
									
								
								PyroFetes/DTO/ProductEffect/Request/ProductEffectDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								PyroFetes/DTO/ProductEffect/Request/ProductEffectDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| namespace PyroFetes.DTO.ProductEffect.Request; | ||||
|  | ||||
| // DTO utilisé pour créer ou mettre à jour la relation Product <-> Effect | ||||
| public class ProductEffectDto | ||||
| { | ||||
|     public int ProductId { get; set; }       // Id du produit (pour update) | ||||
|     public int EffectId { get; set; }      // Id de l'effet | ||||
| } | ||||
							
								
								
									
										12
									
								
								PyroFetes/DTO/ProductEffect/Response/GetProductEffectDto.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								PyroFetes/DTO/ProductEffect/Response/GetProductEffectDto.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| namespace PyroFetes.DTO.ProductEffect.Response; | ||||
|  | ||||
| // DTO utilisé pour renvoyer les informations d’un produit lié à un effet | ||||
|  | ||||
| public class GetProductEffectDto | ||||
| { | ||||
|     // Identifiant du produit concerné | ||||
|     public int ProductId { get; set; } | ||||
|  | ||||
|     // Identifiant de l'effet | ||||
|     public int EffectId { get; set; } | ||||
| } | ||||
| @@ -0,0 +1,10 @@ | ||||
| namespace PyroFetes.DTO.Product.Request | ||||
| { | ||||
|     // DTO utilisé pour créer ou mettre à jour la relation Product <-> Supplier | ||||
|     public class ProductSupplierPriceDto | ||||
|     { | ||||
|         public int ProductId { get; set; }       // Id du produit (pour update) | ||||
|         public int SupplierId { get; set; }      // Id du fournisseur | ||||
|         public decimal SellingPrice { get; set; } // Prix de vente | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,18 @@ | ||||
| namespace PyroFetes.DTO.Product.Response | ||||
| { | ||||
|     // DTO utilisé pour renvoyer les informations d’un fournisseur lié à un produit | ||||
|     public class GetProductSupplierDto | ||||
|     { | ||||
|         // Identifiant du produit concerné | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Identifiant du fournisseur | ||||
|         public int SupplierId { get; set; } | ||||
|  | ||||
|         // Nom du fournisseur | ||||
|         public string SupplierName { get; set; } = string.Empty; | ||||
|  | ||||
|         // Prix de vente du produit fourni par ce fournisseur | ||||
|         public decimal SellingPrice { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,28 @@ | ||||
| namespace PyroFetes.DTO.Product.Request | ||||
| { | ||||
|     // DTO utilisé lors de la création d’une relation entre un produit et un entrepôt | ||||
|     public class CreateProductWarehouseDto | ||||
|     { | ||||
|         // Identifiant de l'entrepôt concerné | ||||
|         public int WarehouseId { get; set; } | ||||
|  | ||||
|         // Identifiant du produit associé à cet entrepôt | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Quantité du produit disponible dans cet entrepôt | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
|  | ||||
|     // DTO utilisé lors de la mise à jour d’une relation entre un produit et un entrepôt | ||||
|     public class UpdateProductWarehouseDto | ||||
|     { | ||||
|         // Identifiant de l'entrepôt concerné | ||||
|         public int WarehouseId { get; set; } | ||||
|  | ||||
|         // Identifiant du produit associé à cet entrepôt | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Nouvelle quantité du produit dans cet entrepôt | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,18 @@ | ||||
| namespace PyroFetes.DTO.Product.Response | ||||
| { | ||||
|     // DTO utilisé pour renvoyer les informations d’un entrepôt lié à un produit | ||||
|     public class GetProductWarehouseDto | ||||
|     { | ||||
|         // Identifiant de l'entrepôt | ||||
|         public int WarehouseId { get; set; } | ||||
|  | ||||
|         // Identifiant du produit associé à cet entrepôt | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Nom de l'entrepôt (utile pour l’affichage) | ||||
|         public string WarehouseName { get; set; } = string.Empty; | ||||
|  | ||||
|         // Quantité du produit stockée dans cet entrepôt | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,11 +1,37 @@ | ||||
| namespace API.DTO.Supplier.Request; | ||||
|  | ||||
| public class CreateSupplierDto | ||||
| namespace PyroFetes.DTO.Supplier.Request | ||||
| { | ||||
|     public string Name { get; set; } | ||||
|     public string Email { get; set; } | ||||
|     public string PhoneNumber { get; set; }  | ||||
|     public string Adress { get; set; } | ||||
|     public int ZipCode { get; set; } | ||||
|     public string City { get; set; } | ||||
|     // DTO pour créer un nouveau fournisseur | ||||
|     public class CreateSupplierDto | ||||
|     { | ||||
|         // Nom du fournisseur | ||||
|         public string Name { get; set; } | ||||
|  | ||||
|         // Email du fournisseur | ||||
|         public string Email { get; set; } | ||||
|  | ||||
|         // Numéro de téléphone du fournisseur | ||||
|         public string PhoneNumber { get; set; }  | ||||
|  | ||||
|         // Adresse du fournisseur | ||||
|         public string Adress { get; set; } | ||||
|  | ||||
|         // Code postal de l'adresse | ||||
|         public int ZipCode { get; set; } | ||||
|  | ||||
|         // Ville de l'adresse | ||||
|         public string City { get; set; } | ||||
|  | ||||
|         // Liste des produits fournis par ce fournisseur dans la classe SupplierProductPriceDto | ||||
|         public List<SupplierProductPriceDto>? Products { get; set; } | ||||
|     } | ||||
|  | ||||
|     // DTO pour relier un produit et son prix à un fournisseur | ||||
|     public class SupplierProductPriceDto | ||||
|     { | ||||
|         // Identifiant du produit fourni | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Prix de vente du produit par ce fournisseur | ||||
|         public decimal SellingPrice { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,12 +1,30 @@ | ||||
| namespace API.DTO.Supplier.Request; | ||||
|  | ||||
| public class UpdateSupplierDto | ||||
| namespace PyroFetes.DTO.Supplier.Request | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string Name { get; set; } | ||||
|     public string Email { get; set; } | ||||
|     public string PhoneNumber { get; set; }  | ||||
|     public string Adress { get; set; } | ||||
|     public int ZipCode { get; set; } | ||||
|     public string City { get; set; } | ||||
|     // DTO pour mettre à jour un fournisseur existant | ||||
|     public class UpdateSupplierDto | ||||
|     { | ||||
|         // Identifiant du fournisseur à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom du fournisseur | ||||
|         public string Name { get; set; } | ||||
|  | ||||
|         // Email du fournisseur | ||||
|         public string Email { get; set; } | ||||
|  | ||||
|         // Numéro de téléphone du fournisseur | ||||
|         public string PhoneNumber { get; set; }  | ||||
|  | ||||
|         // Adresse du fournisseur | ||||
|         public string Adress { get; set; } | ||||
|  | ||||
|         // Code postal de l'adresse | ||||
|         public int ZipCode { get; set; } | ||||
|  | ||||
|         // Ville de l'adresse | ||||
|         public string City { get; set; } | ||||
|  | ||||
|         // Liste des produits fournis par ce fournisseur relié à la classe SupplierProductPriceDto | ||||
|         public List<SupplierProductPriceDto>? Products { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,12 +1,45 @@ | ||||
| namespace API.DTO.Supplier.Response; | ||||
| using PyroFetes.DTO.Supplier.Request; | ||||
|  | ||||
| public class GetSupplierDto | ||||
| namespace PyroFetes.DTO.Supplier.Response | ||||
| { | ||||
|     public int Id { get; set; } | ||||
|     public string Name { get; set; } | ||||
|     public string Email { get; set; } | ||||
|     public string PhoneNumber { get; set; }  | ||||
|     public string Adress { get; set; } | ||||
|     public int ZipCode { get; set; } | ||||
|     public string City { get; set; } | ||||
|     // DTO pour récupérer les informations d'un fournisseur | ||||
|     public class GetSupplierDto | ||||
|     { | ||||
|         // Identifiant du fournisseur | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom du fournisseur | ||||
|         public string Name { get; set; } | ||||
|  | ||||
|         // Email du fournisseur | ||||
|         public string Email { get; set; } | ||||
|  | ||||
|         // Numéro de téléphone | ||||
|         public string PhoneNumber { get; set; }  | ||||
|  | ||||
|         // Adresse du fournisseur | ||||
|         public string Adress { get; set; } | ||||
|  | ||||
|         // Code postal | ||||
|         public int ZipCode { get; set; } | ||||
|  | ||||
|         // Ville | ||||
|         public string City { get; set; } | ||||
|  | ||||
|         // Liste des produits fournis par la classe SupplierProductPriceDto | ||||
|         public List<SupplierProductPriceDto> Products { get; set; } = new(); | ||||
|     } | ||||
|  | ||||
|     // DTO pour les détails d'un produit lié à un fournisseur | ||||
|     public class GetSupplierProductDto | ||||
|     { | ||||
|         // Identifiant du produit | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Nom du produit | ||||
|         public string ProductName { get; set; } = string.Empty; | ||||
|  | ||||
|         // Prix de vente fourni par le fournisseur | ||||
|         public decimal SellingPrice { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,12 +1,40 @@ | ||||
| namespace API.DTO.Warehouse.Request; | ||||
|  | ||||
| public class CreateWarehouseDto | ||||
| namespace API.DTO.Warehouse.Request | ||||
| { | ||||
|     public string Name {get; set;} | ||||
|     public int MaxWeight {get; set;} | ||||
|     public int Current {get; set;} | ||||
|     public int MinWeight {get; set;} | ||||
|     public string Adress { get; set; } | ||||
|     public int ZipCode { get; set; } | ||||
|     public string City { get; set; } | ||||
| } | ||||
|     // DTO pour créer un entrepôt | ||||
|     public class CreateWarehouseDto | ||||
|     { | ||||
|         // Nom de l'entrepôt | ||||
|         public string Name { get; set; } | ||||
|  | ||||
|         // Poids maximal que l'entrepôt peut contenir | ||||
|         public int MaxWeight { get; set; } | ||||
|  | ||||
|         // Poids actuel stocké | ||||
|         public int Current { get; set; } | ||||
|  | ||||
|         // Poids minimal souhaité | ||||
|         public int MinWeight { get; set; } | ||||
|  | ||||
|         // Adresse de l'entrepôt | ||||
|         public string Adress { get; set; } | ||||
|  | ||||
|         // Code postal | ||||
|         public int ZipCode { get; set; } | ||||
|  | ||||
|         // Ville | ||||
|         public string City { get; set; } | ||||
|   | ||||
|         // Liste des produits à stocker dans cet entrepôt venant de la classe en dessous | ||||
|         public List<CreateWarehouseProductDto>? Products { get; set; } | ||||
|     } | ||||
|  | ||||
|     // DTO pour associer un produit à un entrepôt | ||||
|     public class CreateWarehouseProductDto | ||||
|     { | ||||
|         // Identifiant du produit | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Quantité du produit dans l'entrepôt | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,13 +1,43 @@ | ||||
| namespace  API.DTO.Warehouse.Request; | ||||
|  | ||||
| public class UpdateWarehouseDto | ||||
| namespace API.DTO.Warehouse.Request | ||||
| { | ||||
|     public int Id {get; set;} | ||||
|     public string Name {get; set;} | ||||
|     public int MaxWeight {get; set;} | ||||
|     public int Current {get; set;} | ||||
|     public int MinWeight {get; set;} | ||||
|     public string Adress { get; set; } | ||||
|     public int ZipCode { get; set; } | ||||
|     public string City { get; set; } | ||||
|     // DTO pour mettre à jour un entrepôt | ||||
|     public class UpdateWarehouseDto | ||||
|     { | ||||
|         // Identifiant de l'entrepôt à mettre à jour | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom de l'entrepôt | ||||
|         public string Name { get; set; } | ||||
|  | ||||
|         // Poids maximal que l'entrepôt peut contenir | ||||
|         public int MaxWeight { get; set; } | ||||
|  | ||||
|         // Poids actuel stocké | ||||
|         public int Current { get; set; } | ||||
|  | ||||
|         // Poids minimal souhaité | ||||
|         public int MinWeight { get; set; } | ||||
|  | ||||
|         // Adresse de l'entrepôt | ||||
|         public string Adress { get; set; } | ||||
|  | ||||
|         // Code postal | ||||
|         public int ZipCode { get; set; } | ||||
|  | ||||
|         // Ville | ||||
|         public string City { get; set; } | ||||
|  | ||||
|         // Liste des produits à mettre à jour dans cet entrepôt | ||||
|         public List<UpdateWarehouseProductDto>? Products { get; set; } | ||||
|     } | ||||
|  | ||||
|     // DTO pour mettre à jour la quantité d'un produit dans un entrepôt | ||||
|     public class UpdateWarehouseProductDto | ||||
|     { | ||||
|         // Identifiant du produit | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Nouvelle quantité du produit dans l'entrepôt | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,13 +1,46 @@ | ||||
| namespace  API.DTO.Warehouse.Response; | ||||
|  | ||||
| public class GetWarehouseDto | ||||
| namespace API.DTO.Warehouse.Response | ||||
| { | ||||
|     public int Id {get; set;} | ||||
|     public string Name {get; set;} | ||||
|     public int MaxWeight {get; set;} | ||||
|     public int Current {get; set;} | ||||
|     public int MinWeight {get; set;} | ||||
|     public string Adress { get; set; } | ||||
|     public int ZipCode { get; set; } | ||||
|     public string City { get; set; } | ||||
|     // DTO pour la lecture d'un entrepôt | ||||
|     public class GetWarehouseDto | ||||
|     { | ||||
|         // Identifiant de l'entrepôt | ||||
|         public int Id { get; set; } | ||||
|  | ||||
|         // Nom de l'entrepôt | ||||
|         public string Name { get; set; } | ||||
|  | ||||
|         // Poids maximal que l'entrepôt peut contenir | ||||
|         public int MaxWeight { get; set; } | ||||
|  | ||||
|         // Poids actuellement stocké | ||||
|         public int Current { get; set; } | ||||
|  | ||||
|         // Poids minimal souhaité | ||||
|         public int MinWeight { get; set; } | ||||
|  | ||||
|         // Adresse de l'entrepôt | ||||
|         public string Adress { get; set; } | ||||
|  | ||||
|         // Code postal | ||||
|         public int ZipCode { get; set; } | ||||
|  | ||||
|         // Ville | ||||
|         public string City { get; set; } | ||||
|  | ||||
|         // Liste des produits stockés dans l'entrepôt | ||||
|         public List<WarehouseProductDto>? Products { get; set; } | ||||
|     } | ||||
|  | ||||
|     // DTO pour la lecture d'un produit dans un entrepôt | ||||
|     public class WarehouseProductDto | ||||
|     { | ||||
|         // Identifiant du produit | ||||
|         public int ProductId { get; set; } | ||||
|  | ||||
|         // Nom du produit | ||||
|         public string? ProductName { get; set; } | ||||
|  | ||||
|         // Quantité du produit dans l'entrepôt | ||||
|         public int Quantity { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -1,6 +1,6 @@ | ||||
| using API.DTO.Brand.Request; | ||||
| using API.DTO.Brand.Response; | ||||
| using FastEndpoints; | ||||
| using PyroFetes.DTO.Brand.Request; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Brand; | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| using API.DTO.Brand.Request; | ||||
| using API.DTO.Brand.Response; | ||||
| using FastEndpoints; | ||||
| using PyroFetes.DTO.Brand.Request; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Brand; | ||||
|  | ||||
| @@ -8,7 +8,7 @@ public class UpdateBrandEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/api/brands"); | ||||
|         Put("/api/brands/{Id}");  | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|   | ||||
| @@ -8,7 +8,7 @@ public class UpdateClassificationEndpoint(PyroFetesDbContext pyrofetesdbcontext) | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/api/classifications"); | ||||
|         Put("/api/classifications"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|   | ||||
| @@ -1,35 +0,0 @@ | ||||
| using API.DTO.Color.Request; | ||||
| using API.DTO.Color.Response; | ||||
| using FastEndpoints; | ||||
|  | ||||
| namespace API.Endpoints.Color; | ||||
|  | ||||
| public class CreateColorEndpoint(AppDbContext appDbContext) : Endpoint<CreateColorDto, GetColorDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/color/create"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(CreateColorDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Color color = new() | ||||
|         { | ||||
|             Label = req.Label, | ||||
|         }; | ||||
|          | ||||
|         appDbContext.Colors.Add(color); | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         Console.WriteLine("Added Color"); | ||||
|  | ||||
|         GetColorDto responseDto = new() | ||||
|         { | ||||
|             Id = color.Id, | ||||
|             Label = req.Label, | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
|      | ||||
| } | ||||
							
								
								
									
										36
									
								
								PyroFetes/Endpoints/Color/CreateColorEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								PyroFetes/Endpoints/Color/CreateColorEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | ||||
| using API.DTO.Color.Request; | ||||
| using API.DTO.Color.Response; | ||||
| using FastEndpoints; | ||||
| using PyroFetes; | ||||
|  | ||||
| namespace API.Endpoints.Color; | ||||
|  | ||||
| public class CreateColorEndpoint(PyroFetesDbContext pyroFetesDbContext) : Endpoint<CreateColorDto, GetColorDto> //Instanciation d'une connexion à la bdd dans un endpoint, utilise l'élément de requête CreateColorDto et l'élement de réponse GetColorDto | ||||
| { | ||||
|     public override void Configure() //Configuration de l'endpoint | ||||
|     { | ||||
|         Post("Api/colors"); //Création d'un endpoint pour créer une couleur avec les données de CreateColorDto | ||||
|         AllowAnonymous(); //Laisser passer les requêtes non authentifiées | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(CreateColorDto req, CancellationToken ct) //La méthode HandleAsync est appelée lorsqu'une requête est envoyée à l'endpoint  | ||||
|     { | ||||
|         PyroFetes.Models.Color color = new() | ||||
|         { | ||||
|             Label = req.Label, | ||||
|         }; | ||||
|          | ||||
|         pyroFetesDbContext.Colors.Add(color); | ||||
|         await pyroFetesDbContext.SaveChangesAsync(ct); | ||||
|         Console.WriteLine("Added Color"); | ||||
|  | ||||
|         GetColorDto responseDto = new() | ||||
|         { | ||||
|             Id = color.Id, | ||||
|             Label = req.Label, | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
|      | ||||
| } | ||||
| @@ -1,24 +1,24 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Color; | ||||
| namespace PyroFetes.Endpoints.Color; | ||||
| 
 | ||||
| public class DeleteColorRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
| 
 | ||||
| public class DeleteColorEndpoint(AppDbContext appDbContext) : Endpoint<DeleteColorRequest> | ||||
| public class DeleteColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteColorRequest> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Delete("/colors/{@id}", x => new { x.Id }); | ||||
|         Delete("Api/colors/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|     public override async Task HandleAsync(DeleteColorRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Color? colorToDelete = await appDbContext | ||||
|         Models.Color? colorToDelete = await pyrofetesdbcontext | ||||
|             .Colors | ||||
|             .SingleOrDefaultAsync(a => a.Id == req.Id, cancellationToken: ct);         | ||||
| 
 | ||||
| @@ -29,8 +29,8 @@ public class DeleteColorEndpoint(AppDbContext appDbContext) : Endpoint<DeleteCol | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         appDbContext.Colors.Remove(colorToDelete); | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         pyrofetesdbcontext.Colors.Remove(colorToDelete); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
| 
 | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
| @@ -2,19 +2,19 @@ using API.DTO.Color.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Color; | ||||
| namespace PyroFetes.Endpoints.Color; | ||||
| 
 | ||||
| public class GetAllColorsEndpoint(AppDbContext appDbContext) : EndpointWithoutRequest<List<GetColorDto>> | ||||
| public class GetAllColorsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetColorDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/colors"); | ||||
|         Get("Api/colors"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         List<GetColorDto> responseDto = await appDbContext.Colors | ||||
|         List<GetColorDto> responseDto = await pyrofetesdbcontext.Colors | ||||
|             .Select(a => new GetColorDto | ||||
|                 { | ||||
|                     Id = a.Id, | ||||
| @@ -1,26 +1,25 @@ | ||||
| using API.DTO.Color.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.AspNetCore.Authentication; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Color; | ||||
| namespace PyroFetes.Endpoints.Color; | ||||
| 
 | ||||
| public class GetColorRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
| 
 | ||||
| public class GetColorEndpoint(AppDbContext appDbContext) : Endpoint<GetColorRequest, GetColorDto> | ||||
| public class GetColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetColorRequest, GetColorDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/colors/{@id}", x => new { x.Id}); | ||||
|         Get("Api/colors/{@id}", x => new { x.Id}); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(GetColorRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Color? color = await appDbContext | ||||
|         Models.Color? color = await pyrofetesdbcontext | ||||
|             .Colors | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); | ||||
| 
 | ||||
| @@ -1,22 +1,21 @@ | ||||
| using API.DTO.Color.Request; | ||||
| using API.DTO.Color.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.AspNetCore.Server.Kestrel; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Color; | ||||
| namespace PyroFetes.Endpoints.Color; | ||||
| 
 | ||||
| public class UpdateColorEndpoint(AppDbContext appDbContext) : Endpoint<UpdateColorDto, GetColorDto> | ||||
| public class UpdateColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<UpdateColorDto, GetColorDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Put("/colors/{@id}", x => new { x.Id }); | ||||
|         Put("Api/colors/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(UpdateColorDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Color? colorToEdit = await appDbContext | ||||
|         Models.Color? colorToEdit = await pyrofetesdbcontext | ||||
|             .Colors  | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); | ||||
| 
 | ||||
| @@ -28,7 +27,7 @@ public class UpdateColorEndpoint(AppDbContext appDbContext) : Endpoint<UpdateCol | ||||
| 
 | ||||
|         } | ||||
|         colorToEdit.Label = req.Label; | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
| 
 | ||||
|         GetColorDto responseDto = new() | ||||
|         { | ||||
| @@ -1,14 +1,14 @@ | ||||
| using API.DTO.Effect.Request; | ||||
| using API.DTO.Effect.Response; | ||||
| 
 | ||||
| using FastEndpoints; | ||||
| namespace API.Endpoints.Effect; | ||||
| 
 | ||||
| public class CreateEffectEndpoint(AppDbContext appDbContext) : Endpoint<CreateEffectDto, GetEffectDto> | ||||
| namespace PyroFetes.Endpoints.Effect; | ||||
| 
 | ||||
| public class CreateEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateEffectDto, GetEffectDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/effect/create"); | ||||
|         Post("Api/effects"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
| @@ -19,8 +19,8 @@ public class CreateEffectEndpoint(AppDbContext appDbContext) : Endpoint<CreateEf | ||||
|             Label = req.Label, | ||||
|         }; | ||||
| 
 | ||||
|         appDbContext.Effects.Add(effect); | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         pyrofetesdbcontext.Effects.Add(effect); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         Console.WriteLine("Effect added"); | ||||
| 
 | ||||
|         GetEffectDto responseDto = new() | ||||
| @@ -1,23 +1,23 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Effect; | ||||
| namespace PyroFetes.Endpoints.Effect; | ||||
| 
 | ||||
| public class DeleteEffectRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
| public class DeleteEffectEndpoint(AppDbContext appDbContext) : Endpoint<DeleteEffectRequest> | ||||
| public class DeleteEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteEffectRequest> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Delete("/effects/{@id}", x => new { x.Id }); | ||||
|         Delete("Api/effects/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|     public override async Task HandleAsync(DeleteEffectRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Effect? effectToDelete = await appDbContext | ||||
|         Models.Effect? effectToDelete = await pyrofetesdbcontext | ||||
|             .Effects | ||||
|             .SingleOrDefaultAsync(a => a.Id == req.Id, cancellationToken: ct);         | ||||
| 
 | ||||
| @@ -28,8 +28,8 @@ public class DeleteEffectEndpoint(AppDbContext appDbContext) : Endpoint<DeleteEf | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         appDbContext.Effects.Remove(effectToDelete); | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         pyrofetesdbcontext.Effects.Remove(effectToDelete); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
| 
 | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
| @@ -2,19 +2,19 @@ using API.DTO.Effect.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Effect; | ||||
| namespace PyroFetes.Endpoints.Effect; | ||||
| 
 | ||||
| public class GetAllEffectsEndpoint(AppDbContext appDbContext) : EndpointWithoutRequest<List<GetEffectDto>> | ||||
| public class GetAllEffectsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetEffectDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/effects"); | ||||
|         Get("Api/effects"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         List<GetEffectDto> responseDto = await appDbContext.Effects | ||||
|         List<GetEffectDto> responseDto = await pyrofetesdbcontext.Effects | ||||
|             .Select(a => new GetEffectDto | ||||
|                 { | ||||
|                     Id = a.Id, | ||||
| @@ -1,26 +1,25 @@ | ||||
| using API.DTO.Effect.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.AspNetCore.Authentication; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Effect; | ||||
| namespace PyroFetes.Endpoints.Effect; | ||||
| 
 | ||||
| public class GetEffectRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
| 
 | ||||
| public class GetEffectEndpoint(AppDbContext appDbContext) : Endpoint<GetEffectRequest, GetEffectDto> | ||||
| public class GetEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetEffectRequest, GetEffectDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/effect/{@id}", x => new { x.Id }); | ||||
|         Get("Api/effects/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(GetEffectRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Effect? effect = await appDbContext | ||||
|         Models.Effect? effect = await pyrofetesdbcontext | ||||
|             .Effects | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); | ||||
| 
 | ||||
| @@ -1,22 +1,21 @@ | ||||
| using API.DTO.Effect.Request; | ||||
| using API.DTO.Effect.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.AspNetCore.Server.Kestrel; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Effect; | ||||
| namespace PyroFetes.Endpoints.Effect; | ||||
| 
 | ||||
| public class UpdateEffectEndpoint(AppDbContext appDbContext) : Endpoint<UpdateEffectDto, GetEffectDto> | ||||
| public class UpdateEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<UpdateEffectDto, GetEffectDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Put("/effect/{@id}", x => new { x.Id }); | ||||
|         Put("Api/effects/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(UpdateEffectDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Effect? effectToEdit = await appDbContext | ||||
|         Models.Effect? effectToEdit = await pyrofetesdbcontext | ||||
|             .Effects  | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); | ||||
| 
 | ||||
| @@ -28,7 +27,7 @@ public class UpdateEffectEndpoint(AppDbContext appDbContext) : Endpoint<UpdateEf | ||||
| 
 | ||||
|         } | ||||
|         effectToEdit.Label = req.Label; | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
| 
 | ||||
|         GetEffectDto responseDto = new() | ||||
|         { | ||||
							
								
								
									
										44
									
								
								PyroFetes/Endpoints/Login/CreateLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								PyroFetes/Endpoints/Login/CreateLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| using PyroFetes.DTO.Login.Request; | ||||
| using PyroFetes.DTO.Login.Response; | ||||
| using PasswordGenerator; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Login; | ||||
| using FastEndpoints; | ||||
|  | ||||
| public class CreateLoginEndpoint(PyroFetesDbContext database) : Endpoint<CreateLoginDto, GetLoginDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/api/logins"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(CreateLoginDto req, CancellationToken ct) | ||||
|     { | ||||
|         string? salt = new Password().IncludeLowercase().IncludeUppercase().IncludeNumeric().LengthRequired(24).Next(); | ||||
|          | ||||
|         var login = new Models.Login() | ||||
|         { | ||||
|             Username = req.Username, | ||||
|             FullName = req.FullName, | ||||
|             Password = BCrypt.Net.BCrypt.HashPassword(req.Password + salt), | ||||
|             Salt = salt | ||||
|         }; | ||||
|          | ||||
|         database.Logins.Add(login); | ||||
|          | ||||
|         await database.SaveChangesAsync(ct); | ||||
|         // Pour renvoyer une erreur : Send.StringAsync("Le message d'erreur", 400); | ||||
|          | ||||
|         GetLoginDto responseDto = new() | ||||
|         { | ||||
|             Id = login.Id, | ||||
|             Username = login.Username, | ||||
|             FullName = login.FullName, | ||||
|             Password = login.Password, | ||||
|             Salt = login.Salt | ||||
|         }; | ||||
|          | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										35
									
								
								PyroFetes/Endpoints/Login/DeleteLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								PyroFetes/Endpoints/Login/DeleteLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| using PyroFetes.DTO.Login.Request; | ||||
| using PyroFetes.DTO.Login.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Login; | ||||
|  | ||||
| public class DeleteLoginRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
| public class DeleteLoginEndpoint(PyroFetesDbContext database) : Endpoint<DeleteLoginRequest> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Delete("/api/logins/{@Id}", x => new {x.Id}); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(DeleteLoginRequest req, CancellationToken ct) | ||||
|     { | ||||
|         var login = await database.Logins.SingleOrDefaultAsync(x => x.Id == req.Id, ct); | ||||
|  | ||||
|         if (login == null) | ||||
|         { | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|          | ||||
|         database.Logins.Remove(login); | ||||
|         await database.SaveChangesAsync(ct); | ||||
|          | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										30
									
								
								PyroFetes/Endpoints/Login/GetAllLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								PyroFetes/Endpoints/Login/GetAllLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| using PyroFetes.DTO.Login.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Login; | ||||
|  | ||||
| public class GetAllLoginEndpoint(PyroFetesDbContext database) : EndpointWithoutRequest<List<GetLoginDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/api/logins"); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         var logins = await database.Logins | ||||
|             .Select(login => new GetLoginDto() | ||||
|             { | ||||
|                 Id = login.Id, | ||||
|                 Username = login.Username, | ||||
|                 FullName = login.FullName, | ||||
|                 Password = login.Password, | ||||
|                 Salt = login.Salt | ||||
|             }) | ||||
|             .ToListAsync(ct); | ||||
|          | ||||
|         await Send.OkAsync(logins, ct); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										41
									
								
								PyroFetes/Endpoints/Login/GetLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								PyroFetes/Endpoints/Login/GetLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| using PyroFetes.DTO.Login.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Login; | ||||
|  | ||||
| public class GetLoginRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
| public class GetLoginEndpoint(PyroFetesDbContext database) : Endpoint<GetLoginRequest, GetLoginDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/api/logins/{@Id}", x => new {x.Id}); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(GetLoginRequest req, CancellationToken ct) | ||||
|     { | ||||
|         var login = await database.Logins | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, ct); | ||||
|  | ||||
|         if (login == null) | ||||
|         { | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|          | ||||
|         GetLoginDto responseDto = new() | ||||
|         { | ||||
|             Id = login.Id, | ||||
|             Username = login.Username, | ||||
|             FullName = login.FullName, | ||||
|             Password = login.Password, | ||||
|             Salt = login.Salt | ||||
|         }; | ||||
|          | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										45
									
								
								PyroFetes/Endpoints/Login/UpdateLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								PyroFetes/Endpoints/Login/UpdateLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| using PyroFetes.DTO.Login.Request; | ||||
| using PyroFetes.DTO.Login.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PasswordGenerator; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Login; | ||||
|  | ||||
| public class UpdateLoginEndpoint(PyroFetesDbContext database) : Endpoint<UpdateLoginDto, GetLoginDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Put("/api/logins/{@Id}", x => new {x.Id}); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(UpdateLoginDto req, CancellationToken ct) | ||||
|     { | ||||
|         var login = await database.Logins.SingleOrDefaultAsync(x => x.Id == req.Id, ct); | ||||
|  | ||||
|         if (login == null) | ||||
|         { | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         string? salt = new Password().IncludeLowercase().IncludeUppercase().IncludeNumeric().LengthRequired(24).Next(); | ||||
|          | ||||
|         login.Username = req.Username; | ||||
|         login.FullName = req.FullName; | ||||
|         login.Password = BCrypt.Net.BCrypt.HashPassword(req.Password + salt); | ||||
|         login.Salt = salt; | ||||
|         await database.SaveChangesAsync(ct); | ||||
|          | ||||
|         GetLoginDto responseDto = new() | ||||
|         { | ||||
|             Id = login.Id, | ||||
|             Username = login.Username, | ||||
|             FullName = login.FullName, | ||||
|             Password = login.Password, | ||||
|             Salt = login.Salt | ||||
|         }; | ||||
|          | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										50
									
								
								PyroFetes/Endpoints/Login/UserLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								PyroFetes/Endpoints/Login/UserLoginEndpoint.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| using PyroFetes.DTO.Login.Request; | ||||
| using FastEndpoints.Security; | ||||
| using PyroFetes.DTO.Login.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Login; | ||||
|  | ||||
| public class UserLoginEndpoint(PyroFetesDbContext database) : Endpoint<ConnectLoginDto, GetLoginConnectDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/api/login"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(ConnectLoginDto req, CancellationToken ct) | ||||
|     { | ||||
|         var login = await database.Logins.SingleOrDefaultAsync(x => x.Username == req.Username, ct); | ||||
|  | ||||
|         if (login == null) | ||||
|         { | ||||
|             await Send.UnauthorizedAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|          | ||||
|         if (BCrypt.Net.BCrypt.Verify(req.Password + login.Salt, login.Password)) | ||||
|         { | ||||
|             var jwtToken = JwtBearer.CreateToken( | ||||
|                 o => | ||||
|                 { | ||||
|                     o.SigningKey = "ThisIsASuperSecretJwtKeyThatIsAtLeast32CharsLong"; | ||||
|                     o.ExpireAt = DateTime.UtcNow.AddMinutes(15); | ||||
|                     if (login.Role != null) o.User.Roles.Add(login.Role); | ||||
|                     o.User.Claims.Add(("Username", login.Username)!); | ||||
|                     o.User.Claims.Add(("FullName", login.FullName)!); | ||||
|                     o.User["UserId"] = "001"; | ||||
|                 }); | ||||
|  | ||||
|             GetLoginConnectDto responseDto = new() | ||||
|             { | ||||
|                 Token = jwtToken | ||||
|             }; | ||||
|              | ||||
|             await Send.OkAsync(responseDto, ct); | ||||
|         } | ||||
|         else await Send.UnauthorizedAsync(ct); | ||||
|     } | ||||
| } | ||||
| @@ -1,13 +1,14 @@ | ||||
| using API.DTO.Material.Request; | ||||
| using API.DTO.Material.Response; | ||||
| using FastEndpoints; | ||||
| namespace API.Endpoints.Material; | ||||
| 
 | ||||
| public class CreateMaterialEndpoint(AppDbContext appDbContext) : Endpoint<CreateMaterialDto, GetMaterialDto> | ||||
| namespace PyroFetes.Endpoints.Material; | ||||
| 
 | ||||
| public class CreateMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateMaterialDto, GetMaterialDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/material/create"); | ||||
|         Post("Api/materials"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
| @@ -15,20 +16,20 @@ public class CreateMaterialEndpoint(AppDbContext appDbContext) : Endpoint<Create | ||||
|     { | ||||
|         Models.Material quantity = new() | ||||
|         { | ||||
|             Name = req.Name, | ||||
|             Name = req.Label, | ||||
|             Quantity = req.Quantity, | ||||
|             WarehouseId = req.WarehouseId, | ||||
|         }; | ||||
| 
 | ||||
|         appDbContext.Materials.Add(quantity); | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         pyrofetesdbcontext.Materials.Add(quantity); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         Console.WriteLine("Material added"); | ||||
| 
 | ||||
|         GetMaterialDto responseDto = new() | ||||
|         { | ||||
|             Id = quantity.Id, | ||||
|             WarehouseId = quantity.WarehouseId, | ||||
|             Name = req.Name, | ||||
|             Label = req.Label, | ||||
|         }; | ||||
| 
 | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
| @@ -1,12 +1,12 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Material; | ||||
| namespace PyroFetes.Endpoints.Material; | ||||
| public class DeleteMaterialRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
| public class DeleteMaterialEndpoint(AppDbContext appDbContext) : Endpoint<DeleteMaterialRequest> | ||||
| public class DeleteMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteMaterialRequest> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -16,7 +16,7 @@ public class DeleteMaterialEndpoint(AppDbContext appDbContext) : Endpoint<Delete | ||||
|      | ||||
|     public override async Task HandleAsync(DeleteMaterialRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Material? materialToDelete = await appDbContext | ||||
|         Models.Material? materialToDelete = await pyrofetesdbcontext | ||||
|             .Materials | ||||
|             .SingleOrDefaultAsync(a => a.Id == req.Id, cancellationToken: ct);         | ||||
| 
 | ||||
| @@ -27,8 +27,8 @@ public class DeleteMaterialEndpoint(AppDbContext appDbContext) : Endpoint<Delete | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         appDbContext.Materials.Remove(materialToDelete); | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         pyrofetesdbcontext.Materials.Remove(materialToDelete); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
| 
 | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
| @@ -2,23 +2,23 @@ using API.DTO.Material.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Material; | ||||
| namespace PyroFetes.Endpoints.Material; | ||||
| 
 | ||||
| public class GetAllMaterialsEndpoint(AppDbContext appDbContext) : EndpointWithoutRequest<List<GetMaterialDto>> | ||||
| public class GetAllMaterialsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetMaterialDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/material"); | ||||
|         Get("Api/materials"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         List<GetMaterialDto> responseDto = await appDbContext.Materials | ||||
|         List<GetMaterialDto> responseDto = await pyrofetesdbcontext.Materials | ||||
|             .Select(a => new GetMaterialDto | ||||
|                 { | ||||
|                     Id = a.Id, | ||||
|                     Name = a.Name, | ||||
|                     Label = a.Name, | ||||
|                     Quantity = a.Quantity, | ||||
|                     WarehouseId = a.WarehouseId, | ||||
|                 } | ||||
| @@ -1,26 +1,25 @@ | ||||
| using API.DTO.Material.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.AspNetCore.Authentication; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Material; | ||||
| namespace PyroFetes.Endpoints.Material; | ||||
| 
 | ||||
| public class GetMaterialRequest | ||||
| { | ||||
|     public int Id { get; set; } | ||||
| } | ||||
| 
 | ||||
| public class GetMaterialEndpoint(AppDbContext appDbContext) : Endpoint<GetMaterialRequest, GetMaterialDto> | ||||
| public class GetMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetMaterialRequest, GetMaterialDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/material/{@id}", x => new { x.Id }); | ||||
|         Get("Api/materials/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(GetMaterialRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Material? material = await appDbContext | ||||
|         Models.Material? material = await pyrofetesdbcontext | ||||
|             .Materials | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); | ||||
| 
 | ||||
| @@ -34,7 +33,7 @@ public class GetMaterialEndpoint(AppDbContext appDbContext) : Endpoint<GetMateri | ||||
|         GetMaterialDto responseDto = new() | ||||
|         { | ||||
|             Id = material.Id, | ||||
|             Name = material.Name, | ||||
|             Label = material.Name, | ||||
|             WarehouseId = material.WarehouseId, | ||||
|         }; | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
| @@ -1,22 +1,21 @@ | ||||
| using API.DTO.Material.Request; | ||||
| using API.DTO.Material.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.AspNetCore.Server.Kestrel; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| 
 | ||||
| namespace API.Endpoints.Material; | ||||
| namespace PyroFetes.Endpoints.Material; | ||||
| 
 | ||||
| public class UpdateMaterialEndpoint(AppDbContext appDbContext) : Endpoint<UpdateMaterialDto, GetMaterialDto> | ||||
| public class UpdateMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<UpdateMaterialDto, GetMaterialDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Put("/material/{@id}", x => new { x.Id }); | ||||
|         Put("Api/materials/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
| 
 | ||||
|     public override async Task HandleAsync(UpdateMaterialDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Material? materialToEdit = await appDbContext | ||||
|         Models.Material? materialToEdit = await pyrofetesdbcontext | ||||
|             .Materials  | ||||
|             .SingleOrDefaultAsync(x => x.Id == req.Id, cancellationToken: ct); | ||||
| 
 | ||||
| @@ -27,14 +26,14 @@ public class UpdateMaterialEndpoint(AppDbContext appDbContext) : Endpoint<Update | ||||
|             return; | ||||
| 
 | ||||
|         } | ||||
|         materialToEdit.Name = req.Name; | ||||
|         materialToEdit.Name = req.Label; | ||||
|         materialToEdit.WarehouseId = req.WarehouseId; | ||||
|         await appDbContext.SaveChangesAsync(ct); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
| 
 | ||||
|         GetMaterialDto responseDto = new() | ||||
|         { | ||||
|             Id = req.Id, | ||||
|             Name = req.Name, | ||||
|             Label = req.Label, | ||||
|             WarehouseId = req.WarehouseId, | ||||
|         }; | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
| @@ -8,7 +8,7 @@ public class UpdateMovementEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Post("/api/movements"); | ||||
|         Put("/api/movements"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|   | ||||
| @@ -1,10 +1,13 @@ | ||||
| using FastEndpoints; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Product; | ||||
|  | ||||
| public class CreateProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateProductDto, GetProductDto> | ||||
| public class CreateProductEndpoint(PyroFetesDbContext db)  | ||||
|     : Endpoint<CreateProductDto, GetProductDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -14,28 +17,62 @@ public class CreateProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endp | ||||
|  | ||||
|     public override async Task HandleAsync(CreateProductDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Product product = new () | ||||
|         var product = new Models.Product | ||||
|         { | ||||
|             References = req.References, | ||||
|             Reference = req.References.ToString(), | ||||
|             Name = req.Name!, | ||||
|             Duration = req.Duration, | ||||
|             Caliber = req.Caliber, | ||||
|             ApprovalNumber = req.ApprovalNumber, | ||||
|             Weight = req.Weight, | ||||
|             Nec = req.Nec, | ||||
|             SellingPrice = req.SellingPrice, | ||||
|             Image = req.Image!, | ||||
|             Link = req.Link!, | ||||
|             ProductCategoryId = req.ProductCategoryId, | ||||
|             ClassificationId = req.ClassificationId | ||||
|         }; | ||||
|          | ||||
|         pyrofetesdbcontext.Products.Add(product); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|          | ||||
|         Console.WriteLine("Product créé avec succès !"); | ||||
|  | ||||
|         GetProductDto responseDto = new () | ||||
|         db.Products.Add(product); | ||||
|         await db.SaveChangesAsync(ct); | ||||
|  | ||||
|         // Ajout des fournisseurs liés | ||||
|         if (req.Suppliers is not null && req.Suppliers.Any()) | ||||
|         { | ||||
|             foreach (var s in req.Suppliers) | ||||
|             { | ||||
|                 var price = new Price | ||||
|                 { | ||||
|                     ProductId = product.Id, | ||||
|                     SupplierId = s.SupplierId, | ||||
|                     SellingPrice = s.SellingPrice | ||||
|                 }; | ||||
|                 db.Prices.Add(price); | ||||
|             } | ||||
|             await db.SaveChangesAsync(ct); | ||||
|         } | ||||
|  | ||||
|         // Ajout des entrepôts liés | ||||
|         if (req.Warehouses is not null && req.Warehouses.Any()) | ||||
|         { | ||||
|             foreach (var w in req.Warehouses) | ||||
|             { | ||||
|                 var exists = await db.Warehouses.AnyAsync(x => x.Id == w.WarehouseId, ct); | ||||
|                 if (!exists) | ||||
|                     continue; // sécurité : on ignore les warehouses inexistants | ||||
|  | ||||
|                 var warehouseProduct = new WarehouseProduct | ||||
|                 { | ||||
|                     ProductId = product.Id, | ||||
|                     WarehouseId = w.WarehouseId, | ||||
|                     Quantity = w.Quantity | ||||
|                 }; | ||||
|                 db.WarehouseProducts.Add(warehouseProduct); | ||||
|             } | ||||
|             await db.SaveChangesAsync(ct); | ||||
|         } | ||||
|  | ||||
|         // Construction de la réponse | ||||
|         var response = new GetProductDto | ||||
|         { | ||||
|             Id = product.Id, | ||||
|             Reference = req.References, | ||||
| @@ -49,9 +86,20 @@ public class CreateProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endp | ||||
|             Image = req.Image, | ||||
|             Link = req.Link, | ||||
|             ProductCategoryId = req.ProductCategoryId, | ||||
|             ClassificationId = req.ClassificationId | ||||
|             ClassificationId = req.ClassificationId, | ||||
|             Suppliers = req.Suppliers?.Select(s => new ProductSupplierPriceDto | ||||
|             { | ||||
|                 SupplierId = s.SupplierId, | ||||
|                 SellingPrice = s.SellingPrice | ||||
|             }).ToList() ?? new(), | ||||
|             Warehouses = req.Warehouses?.Select(w => new GetProductWarehouseDto | ||||
|             { | ||||
|                 WarehouseId = w.WarehouseId, | ||||
|                 Quantity = w.Quantity, | ||||
|                 WarehouseName = db.Warehouses.FirstOrDefault(x => x.Id == w.WarehouseId)?.Name ?? string.Empty | ||||
|             }).ToList() ?? new() | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Product; | ||||
|  | ||||
| @@ -8,29 +9,50 @@ public class DeleteProductRequest | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
| public class DeleteProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteProductRequest> | ||||
| public class DeleteProductEndpoint(PyroFetesDbContext db) : Endpoint<DeleteProductRequest> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Delete("/api/products/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|  | ||||
|     public override async Task HandleAsync(DeleteProductRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Product? productToDelete = await pyrofetesdbcontext | ||||
|             .Products | ||||
|             .SingleOrDefaultAsync(p => p.Id == req.Id, cancellationToken: ct); | ||||
|         // Récupérer le produit | ||||
|         var productToDelete = await db.Products | ||||
|             .SingleOrDefaultAsync(p => p.Id == req.Id, ct); | ||||
|  | ||||
|         if (productToDelete == null) | ||||
|         if (productToDelete is null) | ||||
|         { | ||||
|             Console.WriteLine($"Aucun produit avec l'ID {req.Id} trouvé."); | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         pyrofetesdbcontext.Products.Remove(productToDelete); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         // Supprimer les liaisons Price | ||||
|         var relatedPrices = await db.Prices | ||||
|             .Where(p => p.ProductId == req.Id) | ||||
|             .ToListAsync(ct); | ||||
|         if (relatedPrices.Any()) | ||||
|         { | ||||
|             db.Prices.RemoveRange(relatedPrices); | ||||
|         } | ||||
|  | ||||
|         // Supprimer les liaisons WarehouseProduct | ||||
|         var relatedWarehouseProducts = await db.WarehouseProducts | ||||
|             .Where(wp => wp.ProductId == req.Id) | ||||
|             .ToListAsync(ct); | ||||
|         if (relatedWarehouseProducts.Any()) | ||||
|         { | ||||
|             db.WarehouseProducts.RemoveRange(relatedWarehouseProducts); | ||||
|         } | ||||
|  | ||||
|         // Supprimer le produit | ||||
|         db.Products.Remove(productToDelete); | ||||
|  | ||||
|         await db.SaveChangesAsync(ct); | ||||
|         Console.WriteLine($"Produit {req.Id}, ses prix et ses entrepôts liés ont été supprimés avec succès."); | ||||
|  | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
|   | ||||
| @@ -1,10 +1,13 @@ | ||||
| using FastEndpoints; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Product; | ||||
|  | ||||
| public class GetAllProductsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetProductDto>> | ||||
| public class GetAllProductsEndpoint(PyroFetesDbContext db) | ||||
|     : EndpointWithoutRequest<List<GetProductDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -14,26 +17,46 @@ public class GetAllProductsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|  | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         List<GetProductDto> responseDto = await pyrofetesdbcontext.Products | ||||
|             .Select(p => new GetProductDto() | ||||
|                 { | ||||
|                     Id = p.Id, | ||||
|                     Reference = p.References, | ||||
|                     Name = p.Name, | ||||
|                     Duration = p.Duration, | ||||
|                     Caliber = p.Caliber, | ||||
|                     ApprovalNumber = p.ApprovalNumber, | ||||
|                     Weight = p.Weight, | ||||
|                     Nec = p.Nec, | ||||
|                     SellingPrice = p.SellingPrice, | ||||
|                     Image = p.Image, | ||||
|                     Link = p.Link, | ||||
|                     ClassificationId = p.ClassificationId, | ||||
|                     ClassificationLabel = p.Classification!.Label, | ||||
|                     ProductCategoryId = p.ProductCategoryId, | ||||
|                     ProductCategoryLabel = p.ProductCategory!.Label, | ||||
|                 } | ||||
|             ).ToListAsync(ct); | ||||
|         // Inclure toutes les relations nécessaires : Prices + WarehouseProducts + Warehouse | ||||
|         var products = await db.Products | ||||
|             .Include(p => p.Prices) | ||||
|             .Include(p => p.WarehouseProducts) | ||||
|                 .ThenInclude(wp => wp.Warehouse) | ||||
|             .ToListAsync(ct); | ||||
|  | ||||
|         var responseDto = products.Select(p => new GetProductDto | ||||
|         { | ||||
|             Id = p.Id, | ||||
|             // Le modèle Product contient "Reference" (string) — pas "References" (int) | ||||
|             Reference = int.TryParse(p.Reference, out var refInt) ? refInt : 0, | ||||
|             Name = p.Name, | ||||
|             Duration = p.Duration, | ||||
|             Caliber = p.Caliber, | ||||
|             ApprovalNumber = p.ApprovalNumber, | ||||
|             Weight = p.Weight, | ||||
|             Nec = p.Nec, | ||||
|             // Le prix de vente n’est pas dans Product, on le récupère via Prices | ||||
|             SellingPrice = p.Prices.FirstOrDefault()?.SellingPrice ?? 0, | ||||
|             Image = p.Image, | ||||
|             Link = p.Link, | ||||
|             ClassificationId = p.ClassificationId, | ||||
|             ProductCategoryId = p.ProductCategoryId, | ||||
|  | ||||
|             // Liste des fournisseurs liés via Price | ||||
|             Suppliers = p.Prices.Select(pr => new ProductSupplierPriceDto | ||||
|             { | ||||
|                 SupplierId = pr.SupplierId, | ||||
|                 SellingPrice = pr.SellingPrice | ||||
|             }).ToList(), | ||||
|  | ||||
|             // Liste des entrepôts liés via WarehouseProduct | ||||
|             Warehouses = p.WarehouseProducts.Select(wp => new GetProductWarehouseDto | ||||
|             { | ||||
|                 WarehouseId = wp.WarehouseId, | ||||
|                 WarehouseName = wp.Warehouse?.Name ?? string.Empty, | ||||
|                 Quantity = wp.Quantity | ||||
|             }).ToList() | ||||
|         }).ToList(); | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| using FastEndpoints; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Product; | ||||
|  | ||||
| @@ -9,20 +11,23 @@ public class GetProductRequest | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
|  | ||||
| public class GetProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) :Endpoint<GetProductRequest, GetProductDto> | ||||
| public class GetProductEndpoint(PyroFetesDbContext db) | ||||
|     : Endpoint<GetProductRequest, GetProductDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/api/product/{@id}", x => new { x.Id }); | ||||
|         Get("/api/products/{@id}", x => new { x.Id }); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(GetProductRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Product? product = await pyrofetesdbcontext | ||||
|             .Products.Include(product => product.Classification).Include(product => product.ProductCategory) | ||||
|             .SingleOrDefaultAsync(p => p.Id == req.Id, cancellationToken: ct); | ||||
|         // Inclure toutes les relations : Prices + WarehouseProducts + Warehouse | ||||
|         var product = await db.Products | ||||
|             .Include(p => p.Prices) | ||||
|             .Include(p => p.WarehouseProducts) | ||||
|                 .ThenInclude(wp => wp.Warehouse) | ||||
|             .SingleOrDefaultAsync(p => p.Id == req.Id, ct); | ||||
|  | ||||
|         if (product == null) | ||||
|         { | ||||
| @@ -31,23 +36,42 @@ public class GetProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) :Endpoint | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         GetProductDto responseDto = new() | ||||
|         var responseDto = new GetProductDto | ||||
|         { | ||||
|             Id = product.Id, | ||||
|             Reference = product.References, | ||||
|  | ||||
|             // Le modèle Product contient "Reference" (string), pas "References" (int) | ||||
|             Reference = int.TryParse(product.Reference, out var refInt) ? refInt : 0, | ||||
|  | ||||
|             Name = product.Name, | ||||
|             Duration = product.Duration, | ||||
|             Caliber = product.Caliber, | ||||
|             ApprovalNumber = product.ApprovalNumber, | ||||
|             Weight = product.Weight, | ||||
|             Nec = product.Nec, | ||||
|             SellingPrice = product.SellingPrice, | ||||
|  | ||||
|             // Le prix de vente n’est pas dans Product → récupéré via Price | ||||
|             SellingPrice = product.Prices.FirstOrDefault()?.SellingPrice ?? 0, | ||||
|  | ||||
|             Image = product.Image, | ||||
|             Link = product.Link, | ||||
|             ClassificationId = product.ClassificationId, | ||||
|             ClassificationLabel = product.Classification!.Label,  | ||||
|             ProductCategoryId = product.ProductCategoryId,  | ||||
|             ProductCategoryLabel = product.ProductCategory!.Label, | ||||
|             ProductCategoryId = product.ProductCategoryId, | ||||
|  | ||||
|             // Fournisseurs liés via Price | ||||
|             Suppliers = product.Prices.Select(pr => new ProductSupplierPriceDto | ||||
|             { | ||||
|                 SupplierId = pr.SupplierId, | ||||
|                 SellingPrice = pr.SellingPrice | ||||
|             }).ToList(), | ||||
|  | ||||
|             // Entrepôts liés via WarehouseProduct | ||||
|             Warehouses = product.WarehouseProducts.Select(wp => new GetProductWarehouseDto | ||||
|             { | ||||
|                 WarehouseId = wp.WarehouseId, | ||||
|                 WarehouseName = wp.Warehouse?.Name ?? string.Empty, | ||||
|                 Quantity = wp.Quantity | ||||
|             }).ToList() | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|   | ||||
| @@ -1,58 +1,111 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.DTO.Product.Request; | ||||
| using PyroFetes.DTO.Product.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Product; | ||||
|  | ||||
| public class UpdateProductEndpoint(PyroFetesDbContext pyrofetesdbcontext) :Endpoint<UpdateProductDto, GetProductDto> | ||||
| // Endpoint permettant de mettre à jour un produit existant | ||||
| public class UpdateProductEndpoint(PyroFetesDbContext db) | ||||
|     : Endpoint<UpdateProductDto, GetProductDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         // Route HTTP PUT avec un paramètre d'identifiant dans l'URL | ||||
|         Put("/api/products/{@id}", x => new { x.Id }); | ||||
|  | ||||
|         // Autorise les requêtes anonymes (sans authentification) | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(UpdateProductDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Product? productToEdit = await pyrofetesdbcontext | ||||
|             .Products | ||||
|             .SingleOrDefaultAsync(p => p.Id == req.Id, cancellationToken: ct); | ||||
|         // Recherche du produit à mettre à jour, en incluant les relations Prices et WarehouseProducts | ||||
|         var product = await db.Products | ||||
|             .Include(p => p.Prices) | ||||
|             .Include(p => p.WarehouseProducts) | ||||
|             .SingleOrDefaultAsync(p => p.Id == req.Id, ct); | ||||
|  | ||||
|         if (productToEdit == null) | ||||
|         // Si le produit n'existe pas, on retourne une réponse 404 | ||||
|         if (product is null) | ||||
|         { | ||||
|             Console.WriteLine($"Aucun produit avec l'ID {req.Id} trouvé."); | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         productToEdit.References = req.Reference; | ||||
|         productToEdit.Name = req.Name; | ||||
|         productToEdit.Duration = req.Duration; | ||||
|         productToEdit.Caliber = req.Caliber; | ||||
|         productToEdit.ApprovalNumber = req.ApprovalNumber;  | ||||
|         productToEdit.Weight = req.Weight; | ||||
|         productToEdit.Nec = req.Nec; | ||||
|         productToEdit.SellingPrice = req.SellingPrice; | ||||
|         productToEdit.Image = req.Image; | ||||
|         productToEdit.Link = req.Link; | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         // Mise à jour des propriétés principales du produit | ||||
|         product.Reference = req.References.ToString(); // Converti int → string | ||||
|         product.Name = req.Name; | ||||
|         product.Duration = req.Duration; | ||||
|         product.Caliber = req.Caliber; | ||||
|         product.ApprovalNumber = req.ApprovalNumber; | ||||
|         product.Weight = req.Weight; | ||||
|         product.Nec = req.Nec; | ||||
|         product.Image = req.Image; | ||||
|         product.Link = req.Link; | ||||
|         product.ClassificationId = req.ClassificationId; | ||||
|         product.ProductCategoryId = req.ProductCategoryId; | ||||
|  | ||||
|         GetProductDto responseDto = new() | ||||
|         // Mise à jour des prix fournisseurs associés | ||||
|         db.Prices.RemoveRange(product.Prices); | ||||
|         foreach (var s in req.Suppliers) | ||||
|         { | ||||
|             Id = req.Id, | ||||
|             Reference = req.Reference, | ||||
|             db.Prices.Add(new Price | ||||
|             { | ||||
|                 ProductId = product.Id, | ||||
|                 SupplierId = s.SupplierId, | ||||
|                 SellingPrice = s.SellingPrice | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|         // Mise à jour des entrepôts associés | ||||
|         db.WarehouseProducts.RemoveRange(product.WarehouseProducts); | ||||
|         foreach (var w in req.Warehouses) | ||||
|         { | ||||
|             db.WarehouseProducts.Add(new WarehouseProduct | ||||
|             { | ||||
|                 ProductId = product.Id, | ||||
|                 WarehouseId = w.WarehouseId, | ||||
|                 Quantity = w.Quantity | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|         await db.SaveChangesAsync(ct); | ||||
|  | ||||
|         // Construction de la réponse renvoyée au client | ||||
|         var response = new GetProductDto | ||||
|         { | ||||
|             Id = product.Id, | ||||
|             Reference = req.References, // DTO garde int pour cohérence | ||||
|             Name = req.Name, | ||||
|             Duration = req.Duration, | ||||
|             Caliber = req.Caliber, | ||||
|             ApprovalNumber = req.ApprovalNumber, | ||||
|             Weight = req.Weight, | ||||
|             Nec = req.Nec, | ||||
|             SellingPrice = req.SellingPrice, | ||||
|             // Le prix de vente est pris depuis Prices | ||||
|             SellingPrice = req.Suppliers.FirstOrDefault()?.SellingPrice ?? 0, | ||||
|             Image = req.Image, | ||||
|             Link = req.Link | ||||
|             Link = req.Link, | ||||
|             ClassificationId = req.ClassificationId, | ||||
|             ProductCategoryId = req.ProductCategoryId, | ||||
|  | ||||
|             Suppliers = req.Suppliers.Select(s => new ProductSupplierPriceDto | ||||
|             { | ||||
|                 SupplierId = s.SupplierId, | ||||
|                 SellingPrice = s.SellingPrice | ||||
|             }).ToList(), | ||||
|  | ||||
|             Warehouses = req.Warehouses.Select(w => new GetProductWarehouseDto | ||||
|             { | ||||
|                 WarehouseId = w.WarehouseId, | ||||
|                 Quantity = w.Quantity, | ||||
|                 WarehouseName = db.Warehouses | ||||
|                     .FirstOrDefault(x => x.Id == w.WarehouseId)?.Name ?? string.Empty | ||||
|             }).ToList() | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -1,10 +1,13 @@ | ||||
| using API.DTO.Supplier.Request; | ||||
| using API.DTO.Supplier.Response; | ||||
| using PyroFetes.DTO.Supplier.Request; | ||||
| using PyroFetes.DTO.Supplier.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Supplier; | ||||
|  | ||||
| public class CreateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateSupplierDto, GetSupplierDto> | ||||
| public class CreateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext)  | ||||
|     : Endpoint<CreateSupplierDto, GetSupplierDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -14,8 +17,7 @@ public class CreateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|  | ||||
|     public override async Task HandleAsync(CreateSupplierDto req, CancellationToken ct) | ||||
|     { | ||||
|         // Création d'un nouvel objet Supplier | ||||
|         Models.Supplier supplier = new() | ||||
|         var supplier = new Models.Supplier | ||||
|         { | ||||
|             Name = req.Name, | ||||
|             Email = req.Email, | ||||
| @@ -24,15 +26,27 @@ public class CreateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|             ZipCode = req.ZipCode, | ||||
|             City = req.City | ||||
|         }; | ||||
|          | ||||
|         // Ajout à la base et sauvegarde | ||||
|  | ||||
|         pyrofetesdbcontext.Suppliers.Add(supplier); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|          | ||||
|         Console.WriteLine("Fournisseur créé avec succès !"); | ||||
|  | ||||
|         // Préparation de la réponse | ||||
|         GetSupplierDto responseDto = new() | ||||
|         // Ajout des liaisons Price si produits renseignés | ||||
|         if (req.Products is not null && req.Products.Any()) | ||||
|         { | ||||
|             foreach (var p in req.Products) | ||||
|             { | ||||
|                 var price = new Price | ||||
|                 { | ||||
|                     SupplierId = supplier.Id, | ||||
|                     ProductId = p.ProductId, | ||||
|                     SellingPrice = p.SellingPrice | ||||
|                 }; | ||||
|                 pyrofetesdbcontext.Prices.Add(price); | ||||
|             } | ||||
|             await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         } | ||||
|  | ||||
|         var response = new GetSupplierDto | ||||
|         { | ||||
|             Id = supplier.Id, | ||||
|             Name = supplier.Name, | ||||
| @@ -43,6 +57,6 @@ public class CreateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|             City = supplier.City | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| @@ -1,5 +1,6 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Supplier; | ||||
|  | ||||
| @@ -18,19 +19,32 @@ public class DeleteSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|      | ||||
|     public override async Task HandleAsync(DeleteSupplierRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Supplier? supplierToDelete = await pyrofetesdbcontext | ||||
|         var supplierToDelete = await pyrofetesdbcontext | ||||
|             .Suppliers | ||||
|             .SingleOrDefaultAsync(s => s.Id == req.Id, cancellationToken: ct); | ||||
|             .SingleOrDefaultAsync(s => s.Id == req.Id, ct); | ||||
|  | ||||
|         if (supplierToDelete == null) | ||||
|         if (supplierToDelete is null) | ||||
|         { | ||||
|             Console.WriteLine($"Aucun fournisseur avec l'ID {req.Id} trouvé."); | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         // Supprimer les liaisons Price avant le fournisseur | ||||
|         var relatedPrices = await pyrofetesdbcontext.Prices | ||||
|             .Where(p => p.SupplierId == req.Id) | ||||
|             .ToListAsync(ct); | ||||
|  | ||||
|         if (relatedPrices.Any()) | ||||
|         { | ||||
|             pyrofetesdbcontext.Prices.RemoveRange(relatedPrices); | ||||
|         } | ||||
|  | ||||
|         // Supprimer le fournisseur | ||||
|         pyrofetesdbcontext.Suppliers.Remove(supplierToDelete); | ||||
|  | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         Console.WriteLine($"Fournisseur {req.Id} et ses prix liés supprimés avec succès."); | ||||
|  | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
|   | ||||
| @@ -1,10 +1,13 @@ | ||||
| using API.DTO.Supplier.Response; | ||||
| using PyroFetes.DTO.Supplier.Response; | ||||
| using PyroFetes.DTO.Supplier.Request; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Supplier; | ||||
|  | ||||
| public class GetAllSuppliersEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetSupplierDto>> | ||||
| public class GetAllSuppliersEndpoint(PyroFetesDbContext pyrofetesdbcontext) | ||||
|     : EndpointWithoutRequest<List<GetSupplierDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -14,19 +17,28 @@ public class GetAllSuppliersEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|  | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         List<GetSupplierDto> responseDto = await pyrofetesdbcontext.Suppliers | ||||
|             .Select(s => new GetSupplierDto | ||||
|             { | ||||
|                 Id = s.Id, | ||||
|                 Name = s.Name!, | ||||
|                 Email = s.Email!, | ||||
|                 PhoneNumber = s.Phone!, | ||||
|                 Adress = s.Address!, | ||||
|                 ZipCode = s.ZipCode, | ||||
|                 City = s.City! | ||||
|             }) | ||||
|         var suppliers = await pyrofetesdbcontext.Suppliers | ||||
|             .Include(s => s.Prices) | ||||
|             .ToListAsync(ct); | ||||
|  | ||||
|         var responseDto = suppliers.Select(s => new GetSupplierDto | ||||
|         { | ||||
|             Id = s.Id, | ||||
|             Name = s.Name!, | ||||
|             Email = s.Email!, | ||||
|             PhoneNumber = s.Phone!, | ||||
|             Adress = s.Address!, | ||||
|             ZipCode = s.ZipCode, | ||||
|             City = s.City!, | ||||
|  | ||||
|             // 🔹 Liste des produits liés via Price | ||||
|             Products = s.Prices.Select(pr => new SupplierProductPriceDto | ||||
|             { | ||||
|                 ProductId = pr.ProductId, | ||||
|                 SellingPrice = pr.SellingPrice | ||||
|             }).ToList() | ||||
|         }).ToList(); | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|     } | ||||
| } | ||||
| @@ -1,4 +1,5 @@ | ||||
| using API.DTO.Supplier.Response; | ||||
| using PyroFetes.DTO.Supplier.Request; | ||||
| using PyroFetes.DTO.Supplier.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
|  | ||||
| @@ -9,7 +10,8 @@ public class GetSupplierRequest | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
| public class GetSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetSupplierRequest, GetSupplierDto> | ||||
| public class GetSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) | ||||
|     : Endpoint<GetSupplierRequest, GetSupplierDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -19,9 +21,9 @@ public class GetSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | ||||
|  | ||||
|     public override async Task HandleAsync(GetSupplierRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Supplier? supplier = await pyrofetesdbcontext | ||||
|             .Suppliers | ||||
|             .SingleOrDefaultAsync(s => s.Id == req.Id, cancellationToken: ct); | ||||
|         var supplier = await pyrofetesdbcontext.Suppliers | ||||
|             .Include(s => s.Prices) | ||||
|             .SingleOrDefaultAsync(s => s.Id == req.Id, ct); | ||||
|  | ||||
|         if (supplier == null) | ||||
|         { | ||||
| @@ -30,7 +32,7 @@ public class GetSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         GetSupplierDto responseDto = new() | ||||
|         var responseDto = new GetSupplierDto | ||||
|         { | ||||
|             Id = supplier.Id, | ||||
|             Name = supplier.Name!, | ||||
| @@ -38,7 +40,14 @@ public class GetSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | ||||
|             PhoneNumber = supplier.Phone!, | ||||
|             Adress = supplier.Address!, | ||||
|             ZipCode = supplier.ZipCode, | ||||
|             City = supplier.City! | ||||
|             City = supplier.City!, | ||||
|  | ||||
|             // Produits liés | ||||
|             Products = supplier.Prices.Select(p => new SupplierProductPriceDto | ||||
|             { | ||||
|                 ProductId = p.ProductId, | ||||
|                 SellingPrice = p.SellingPrice | ||||
|             }).ToList() | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| using API.DTO.Supplier.Request; | ||||
| using API.DTO.Supplier.Response; | ||||
| using PyroFetes.DTO.Supplier.Request; | ||||
| using PyroFetes.DTO.Supplier.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Supplier; | ||||
|  | ||||
| @@ -15,18 +16,16 @@ public class UpdateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|  | ||||
|     public override async Task HandleAsync(UpdateSupplierDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Supplier? supplierToEdit = await pyrofetesdbcontext | ||||
|         var supplierToEdit = await pyrofetesdbcontext | ||||
|             .Suppliers | ||||
|             .SingleOrDefaultAsync(s => s.Id == req.Id, cancellationToken: ct); | ||||
|             .Include(s => s.Prices) | ||||
|             .SingleOrDefaultAsync(s => s.Id == req.Id, ct); | ||||
|  | ||||
|         if (supplierToEdit == null) | ||||
|         if (supplierToEdit is null) | ||||
|         { | ||||
|             Console.WriteLine($"Aucun fournisseur avec l'ID {req.Id} trouvé."); | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         // Mise à jour des propriétés | ||||
|         supplierToEdit.Name = req.Name; | ||||
|         supplierToEdit.Email = req.Email; | ||||
|         supplierToEdit.Phone = req.PhoneNumber; | ||||
| @@ -34,9 +33,28 @@ public class UpdateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|         supplierToEdit.ZipCode = req.ZipCode; | ||||
|         supplierToEdit.City = req.City; | ||||
|  | ||||
|         if (req.Products is not null) | ||||
|         { | ||||
|             // Supprimer les anciennes liaisons | ||||
|             var existingPrices = pyrofetesdbcontext.Prices | ||||
|                 .Where(p => p.SupplierId == supplierToEdit.Id); | ||||
|             pyrofetesdbcontext.Prices.RemoveRange(existingPrices); | ||||
|  | ||||
|             // Ajouter les nouvelles liaisons | ||||
|             foreach (var p in req.Products) | ||||
|             { | ||||
|                 pyrofetesdbcontext.Prices.Add(new Price | ||||
|                 { | ||||
|                     SupplierId = supplierToEdit.Id, | ||||
|                     ProductId = p.ProductId, | ||||
|                     SellingPrice = p.SellingPrice | ||||
|                 }); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|  | ||||
|         GetSupplierDto responseDto = new() | ||||
|         var response = new GetSupplierDto | ||||
|         { | ||||
|             Id = supplierToEdit.Id, | ||||
|             Name = supplierToEdit.Name, | ||||
| @@ -47,6 +65,6 @@ public class UpdateSupplierEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | ||||
|             City = supplierToEdit.City | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -1,10 +1,12 @@ | ||||
| using API.DTO.Warehouse.Request; | ||||
| using API.DTO.Warehouse.Response; | ||||
| using FastEndpoints; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Warehouse; | ||||
|  | ||||
| public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateWarehouseDto, GetWarehouseDto> | ||||
| public class CreateWarehouseEndpoint(PyroFetesDbContext db)  | ||||
|     : Endpoint<CreateWarehouseDto, GetWarehouseDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -14,7 +16,7 @@ public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|  | ||||
|     public override async Task HandleAsync(CreateWarehouseDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Warehouse warehouse = new() | ||||
|         var warehouse = new Models.Warehouse | ||||
|         { | ||||
|             Name = req.Name, | ||||
|             MaxWeight = req.MaxWeight, | ||||
| @@ -24,13 +26,27 @@ public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|             ZipCode = req.ZipCode, | ||||
|             City = req.City | ||||
|         }; | ||||
|          | ||||
|         pyrofetesdbcontext.Warehouses.Add(warehouse); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|          | ||||
|         Console.WriteLine("Entrepôt créé avec succès !"); | ||||
|  | ||||
|         GetWarehouseDto responseDto = new() | ||||
|         db.Warehouses.Add(warehouse); | ||||
|         await db.SaveChangesAsync(ct); | ||||
|  | ||||
|         // 🔹 Ajout des produits liés à cet entrepôt | ||||
|         if (req.Products is not null && req.Products.Any()) | ||||
|         { | ||||
|             foreach (var p in req.Products) | ||||
|             { | ||||
|                 var warehouseProduct = new WarehouseProduct | ||||
|                 { | ||||
|                     WarehouseId = warehouse.Id, | ||||
|                     ProductId = p.ProductId, | ||||
|                     Quantity = p.Quantity | ||||
|                 }; | ||||
|                 db.WarehouseProducts.Add(warehouseProduct); | ||||
|             } | ||||
|             await db.SaveChangesAsync(ct); | ||||
|         } | ||||
|  | ||||
|         var response = new GetWarehouseDto | ||||
|         { | ||||
|             Id = warehouse.Id, | ||||
|             Name = warehouse.Name, | ||||
| @@ -42,6 +58,6 @@ public class CreateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|             City = warehouse.City | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| @@ -1,5 +1,6 @@ | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Warehouse; | ||||
|  | ||||
| @@ -8,18 +9,18 @@ public class DeleteWarehouseRequest | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
| public class DeleteWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<DeleteWarehouseRequest> | ||||
| public class DeleteWarehouseEndpoint(PyroFetesDbContext db) : Endpoint<DeleteWarehouseRequest> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Delete("/api/warehouse/{@id}", x => new { x.Id }); | ||||
|         Delete("/api/warehouse/{id}"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|      | ||||
|     public override async Task HandleAsync(DeleteWarehouseRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Warehouse? warehouseToDelete = await pyrofetesdbcontext | ||||
|             .Warehouses | ||||
|         // On charge aussi les WarehouseProducts liés pour les supprimer proprement | ||||
|         var warehouseToDelete = await db.Warehouses | ||||
|             .Include(w => w.WarehouseProducts) | ||||
|             .SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct); | ||||
|  | ||||
|         if (warehouseToDelete == null) | ||||
| @@ -29,9 +30,21 @@ public class DeleteWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         pyrofetesdbcontext.Warehouses.Remove(warehouseToDelete); | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         // 🔹 Suppression des relations WarehouseProduct avant l'entrepôt | ||||
|         var relatedWarehouseProducts = await db.WarehouseProducts | ||||
|             .Where(wp => wp.WarehouseId == req.Id) | ||||
|             .ToListAsync(ct); | ||||
|  | ||||
|         if (relatedWarehouseProducts.Any()) | ||||
|         { | ||||
|             db.WarehouseProducts.RemoveRange(relatedWarehouseProducts); | ||||
|         } | ||||
|  | ||||
|         // 🔹 Suppression de l’entrepôt | ||||
|         db.Warehouses.Remove(warehouseToDelete); | ||||
|         await db.SaveChangesAsync(ct); | ||||
|  | ||||
|         Console.WriteLine($"Entrepôt {warehouseToDelete.Name} (ID {req.Id}) supprimé avec succès."); | ||||
|         await Send.NoContentAsync(ct); | ||||
|     } | ||||
| } | ||||
| @@ -1,10 +1,13 @@ | ||||
| using API.DTO.Warehouse.Response; | ||||
| using API.DTO.Warehouse.Request; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Warehouse; | ||||
|  | ||||
| public class GetAllWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : EndpointWithoutRequest<List<GetWarehouseDto>> | ||||
| public class GetAllWarehouseEndpoint(PyroFetesDbContext db) | ||||
|     : EndpointWithoutRequest<List<GetWarehouseDto>> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
| @@ -14,20 +17,30 @@ public class GetAllWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|  | ||||
|     public override async Task HandleAsync(CancellationToken ct) | ||||
|     { | ||||
|         List<GetWarehouseDto> responseDto = await pyrofetesdbcontext.Warehouses | ||||
|             .Select(w => new GetWarehouseDto | ||||
|             { | ||||
|                 Id = w.Id, | ||||
|                 Name = w.Name, | ||||
|                 MaxWeight = w.MaxWeight, | ||||
|                 Current = w.Current, | ||||
|                 MinWeight = w.MinWeight, | ||||
|                 Adress = w.Address, | ||||
|                 ZipCode = w.ZipCode, | ||||
|                 City = w.City | ||||
|             }) | ||||
|         // 🔹 On inclut les relations avec WarehouseProducts et Product | ||||
|         var warehouses = await db.Warehouses | ||||
|             .Include(w => w.WarehouseProducts) | ||||
|             .ThenInclude(wp => wp.Product) | ||||
|             .ToListAsync(ct); | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         var response = warehouses.Select(w => new GetWarehouseDto | ||||
|         { | ||||
|             Id = w.Id, | ||||
|             Name = w.Name, | ||||
|             MaxWeight = w.MaxWeight, | ||||
|             Current = w.Current, | ||||
|             MinWeight = w.MinWeight, | ||||
|             Adress = w.Address, | ||||
|             ZipCode = w.ZipCode, | ||||
|             City = w.City, | ||||
|             Products = w.WarehouseProducts.Select(wp => new WarehouseProductDto | ||||
|             { | ||||
|                 ProductId = wp.ProductId, | ||||
|                 ProductName = wp.Product?.Name, | ||||
|                 Quantity = wp.Quantity | ||||
|             }).ToList() | ||||
|         }).ToList(); | ||||
|  | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| @@ -1,6 +1,7 @@ | ||||
| using API.DTO.Warehouse.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Warehouse; | ||||
|  | ||||
| @@ -9,28 +10,32 @@ public class GetWarehouseRequest | ||||
|     public int Id { get; set; } | ||||
| } | ||||
|  | ||||
| public class GetWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<GetWarehouseRequest, GetWarehouseDto> | ||||
| public class GetWarehouseEndpoint(PyroFetesDbContext db) | ||||
|     : Endpoint<GetWarehouseRequest, GetWarehouseDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Get("/api/warehouses/{@id}", x => new { x.Id }); | ||||
|         // Pas de "@id" ici, juste {id} | ||||
|         Get("/api/warehouses/{Id}"); | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(GetWarehouseRequest req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Warehouse? warehouse = await pyrofetesdbcontext | ||||
|             .Warehouses | ||||
|         // 🔹 Inclut les produits associés à cet entrepôt | ||||
|         var warehouse = await db.Warehouses | ||||
|             .Include(w => w.WarehouseProducts) | ||||
|             .ThenInclude(wp => wp.Product) | ||||
|             .SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct); | ||||
|  | ||||
|         if (warehouse == null) | ||||
|         { | ||||
|             Console.WriteLine($"Aucun entrepôt avec l'ID {req.Id} trouvé."); | ||||
|             Console.WriteLine($" Aucun entrepôt avec l'ID {req.Id} trouvé."); | ||||
|             await Send.NotFoundAsync(ct); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         GetWarehouseDto responseDto = new() | ||||
|         var response = new GetWarehouseDto | ||||
|         { | ||||
|             Id = warehouse.Id, | ||||
|             Name = warehouse.Name!, | ||||
| @@ -39,9 +44,15 @@ public class GetWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpo | ||||
|             MinWeight = warehouse.MinWeight, | ||||
|             Adress = warehouse.Address!, | ||||
|             ZipCode = warehouse.ZipCode, | ||||
|             City = warehouse.City! | ||||
|             City = warehouse.City!, | ||||
|             Products = warehouse.WarehouseProducts.Select(wp => new WarehouseProductDto | ||||
|             { | ||||
|                 ProductId = wp.ProductId, | ||||
|                 ProductName = wp.Product?.Name, | ||||
|                 Quantity = wp.Quantity | ||||
|             }).ToList() | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| @@ -2,21 +2,25 @@ | ||||
| using API.DTO.Warehouse.Response; | ||||
| using FastEndpoints; | ||||
| using Microsoft.EntityFrameworkCore; | ||||
| using PyroFetes.Models; | ||||
|  | ||||
| namespace PyroFetes.Endpoints.Warehouse; | ||||
|  | ||||
| public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<UpdateWarehouseDto, GetWarehouseDto> | ||||
| public class UpdateWarehouseEndpoint(PyroFetesDbContext db) | ||||
|     : Endpoint<UpdateWarehouseDto, GetWarehouseDto> | ||||
| { | ||||
|     public override void Configure() | ||||
|     { | ||||
|         Put("/api/warehouses/{@id}", x => new { x.Id }); | ||||
|         // Utilise {id} plutôt que {@id} | ||||
|         Put("/api/warehouses/{Id}");        | ||||
|         AllowAnonymous(); | ||||
|     } | ||||
|  | ||||
|     public override async Task HandleAsync(UpdateWarehouseDto req, CancellationToken ct) | ||||
|     { | ||||
|         Models.Warehouse? warehouseToEdit = await pyrofetesdbcontext | ||||
|             .Warehouses | ||||
|         // 🔹 On inclut les produits existants pour pouvoir les modifier | ||||
|         var warehouseToEdit = await db.Warehouses | ||||
|             .Include(w => w.WarehouseProducts) | ||||
|             .SingleOrDefaultAsync(w => w.Id == req.Id, cancellationToken: ct); | ||||
|  | ||||
|         if (warehouseToEdit == null) | ||||
| @@ -26,7 +30,7 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         // Mise à jour des champs | ||||
|         // 🔹 Mise à jour des champs de base | ||||
|         warehouseToEdit.Name = req.Name; | ||||
|         warehouseToEdit.MaxWeight = req.MaxWeight; | ||||
|         warehouseToEdit.Current = req.Current; | ||||
| @@ -35,9 +39,30 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|         warehouseToEdit.ZipCode = req.ZipCode; | ||||
|         warehouseToEdit.City = req.City; | ||||
|  | ||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); | ||||
|         // 🔹 Gestion des produits associés | ||||
|         if (req.Products is not null) | ||||
|         { | ||||
|             // On supprime les anciens liens pour recréer proprement | ||||
|             var existingLinks = warehouseToEdit.WarehouseProducts.ToList(); | ||||
|             if (existingLinks.Any()) | ||||
|                 db.WarehouseProducts.RemoveRange(existingLinks); | ||||
|  | ||||
|         GetWarehouseDto responseDto = new() | ||||
|             foreach (var p in req.Products) | ||||
|             { | ||||
|                 var newLink = new WarehouseProduct | ||||
|                 { | ||||
|                     WarehouseId = warehouseToEdit.Id, | ||||
|                     ProductId = p.ProductId, | ||||
|                     Quantity = p.Quantity | ||||
|                 }; | ||||
|                 db.WarehouseProducts.Add(newLink); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         await db.SaveChangesAsync(ct); | ||||
|  | ||||
|         // 🔹 On renvoie la version mise à jour | ||||
|         var response = new GetWarehouseDto | ||||
|         { | ||||
|             Id = warehouseToEdit.Id, | ||||
|             Name = warehouseToEdit.Name, | ||||
| @@ -46,9 +71,16 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | ||||
|             MinWeight = warehouseToEdit.MinWeight, | ||||
|             Adress = warehouseToEdit.Address, | ||||
|             ZipCode = warehouseToEdit.ZipCode, | ||||
|             City = warehouseToEdit.City | ||||
|             City = warehouseToEdit.City, | ||||
|             Products = warehouseToEdit.WarehouseProducts.Select(wp => new WarehouseProductDto | ||||
|             { | ||||
|                 ProductId = wp.ProductId, | ||||
|                 ProductName = wp.Product?.Name, | ||||
|                 Quantity = wp.Quantity | ||||
|             }).ToList() | ||||
|         }; | ||||
|  | ||||
|         await Send.OkAsync(responseDto, ct); | ||||
|         Console.WriteLine($"Entrepôt {warehouseToEdit.Name} mis à jour avec succès."); | ||||
|         await Send.OkAsync(response, ct); | ||||
|     } | ||||
| } | ||||
| } | ||||
|   | ||||
							
								
								
									
										13
									
								
								PyroFetes/Models/Login.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								PyroFetes/Models/Login.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| using System.ComponentModel.DataAnnotations; | ||||
|  | ||||
| namespace PyroFetes.Models; | ||||
|  | ||||
| public class Login | ||||
| { | ||||
|     [Key] public int Id { get; set; } | ||||
|     [Required, MaxLength(100)] public string? Username { get; set; } | ||||
|     [Required, MaxLength(200)] public string? FullName { get; set; } | ||||
|     [Required, Length(60, 60)] public string? Password { get; set; } | ||||
|     [Required, Length(24, 24)] public string? Salt { get; set; } | ||||
|     [Required, MaxLength(100)] public string? Role { get; set; } | ||||
| } | ||||
| @@ -5,14 +5,13 @@ namespace PyroFetes.Models | ||||
|     public class Product | ||||
|     { | ||||
|         [Key] public int Id { get; set; } | ||||
|         [Required] public int References { get; set; } | ||||
|         [Required, MaxLength(20)] public string? Reference { get; set; } | ||||
|         [Required, MaxLength(100)] public string? Name { get; set; } | ||||
|         [Required] public decimal Duration {get; set;}  | ||||
|         [Required] public decimal Caliber { get; set; } | ||||
|         [Required] public int ApprovalNumber { get; set; } | ||||
|         [Required] public decimal Weight { get; set; } | ||||
|         [Required] public decimal Nec { get; set; } | ||||
|         [Required] public decimal SellingPrice { get; set; } | ||||
|         [Required] public string? Image { get; set; } | ||||
|         [Required, MaxLength(200)] public string? Link { get; set; } | ||||
|         [Required] public int MinimalQuantity { get; set; } | ||||
|   | ||||
| @@ -2,18 +2,27 @@ using API; | ||||
| using FastEndpoints; | ||||
| using FastEndpoints.Swagger; | ||||
| using PyroFetes; | ||||
| using FastEndpoints.Security; | ||||
|  | ||||
|  | ||||
| WebApplicationBuilder builder = WebApplication.CreateBuilder(args); | ||||
|  | ||||
| // On ajoute ici FastEndpoints, un framework REPR et Swagger aux services disponibles dans le projet | ||||
| builder.Services.AddFastEndpoints().SwaggerDocument(); | ||||
| builder.Services | ||||
|     .AddAuthenticationJwtBearer(s => s.SigningKey = "ThisIsASuperSecretJwtKeyThatIsAtLeast32CharsLong") | ||||
|     .AddAuthorization() | ||||
|     .AddFastEndpoints() | ||||
|     .SwaggerDocument(); | ||||
|  | ||||
| // On ajoute ici la configuration de la base de données | ||||
| builder.Services.AddDbContext<PyroFetesDbContext>(); | ||||
|  | ||||
| // On construit l'application en lui donnant vie | ||||
| WebApplication app = builder.Build(); | ||||
| app.UseFastEndpoints().UseSwaggerGen(); | ||||
| app.UseAuthentication() | ||||
|     .UseAuthorization() | ||||
|     .UseFastEndpoints() | ||||
|     .UseSwaggerGen(); | ||||
|  | ||||
| app.UseHttpsRedirection(); | ||||
|  | ||||
|   | ||||
| @@ -7,16 +7,19 @@ | ||||
|     </PropertyGroup> | ||||
|  | ||||
|     <ItemGroup> | ||||
|         <PackageReference Include="BCrypt.Net-Next" Version="4.0.3" /> | ||||
|         <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.Design" Version="8.0.20"> | ||||
|           <PrivateAssets>all</PrivateAssets> | ||||
|           <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> | ||||
|         </PackageReference> | ||||
|         <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="8.0.20" /> | ||||
|         <PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2"/> | ||||
|         <PackageReference Include="PasswordGenerator" Version="2.1.0" /> | ||||
|         <PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2" /> | ||||
|     </ItemGroup> | ||||
|  | ||||
| </Project> | ||||
|   | ||||
| @@ -49,6 +49,7 @@ public class PyroFetesDbContext : DbContext | ||||
|     public DbSet<User> Users { get; set; } | ||||
|     public DbSet<Warehouse> Warehouses { get; set; } | ||||
|     public DbSet<WarehouseProduct> WarehouseProducts { get; set; } | ||||
|     public DbSet<Login> Logins { get; set; } | ||||
|  | ||||
|     // Database configuration | ||||
|     protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) | ||||
|   | ||||
							
								
								
									
										50
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| # Gestionnaire de Stocks et Commandes | ||||
|  | ||||
| Cette application web permet de **suivre les stocks**, **automatiser les commandes fournisseurs** et **gérer le cycle complet d’approvisionnement**.   | ||||
| Elle est conçue pour simplifier le travail des entreprises en offrant une vue en temps réel sur les produits, leurs fournisseurs et l’état des livraisons. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## ✨ Fonctionnalités principales | ||||
|  | ||||
| ### 1️⃣ Suivi et réapprovisionnement des stocks | ||||
| - Définissez un **niveau minimal de stock** pour chaque produit.   | ||||
| - Surveillez les **niveaux en temps réel** grâce à une interface claire.   | ||||
| - Lorsqu’un produit atteint ou descend sous son seuil minimal, le système **génère automatiquement un bon de commande** pour le réapprovisionner. | ||||
|  | ||||
| ### 2️⃣ Gestion des fournisseurs | ||||
| - Enregistrez les informations complètes des fournisseurs : nom, adresse, coordonnées, produits fournis, délais de livraison.   | ||||
| - **Associez un ou plusieurs fournisseurs** à chaque produit.   | ||||
| - Lorsqu’un bon de commande est créé, le système **propose automatiquement les fournisseurs appropriés**. | ||||
|  | ||||
| ### 3️⃣ Devis et bons de commande | ||||
| - Créez des **devis personnalisés** : sélection des produits, quantités, prix, ajout d’un logo, message ou conditions de vente.   | ||||
| - **Imprimez ou exportez** vos devis au format PDF.   | ||||
| - Générez des **bons de commande** en quelques clics, avec personnalisation (logo, conditions d’achat) et exportation en PDF. | ||||
|  | ||||
| ### 4️⃣ Suivi des livraisons | ||||
| - **Transformez un bon de commande en bon de livraison** dès l’expédition des produits par le fournisseur.   | ||||
| - Enregistrez toutes les informations importantes : date d’expédition, transporteur, numéro de suivi, date prévue et date effective de livraison.   | ||||
| - Recevez des **alertes en cas de retard**.   | ||||
| - Gérez la **réception des produits** et vérifiez leur conformité. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## 🗂️ Livrables prévus | ||||
| - **Modèle de données** : diagramme de classes commun à tous les groupes.   | ||||
| - **Interface utilisateur** : maquettes ou prototypes interactifs.   | ||||
| - **Code source commenté** pour une meilleure compréhension.   | ||||
| - **Documentation technique** : description des fonctionnalités, architecture de l’application et API. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## 👥 Équipe | ||||
| - **Mathys**   | ||||
| - **Enzo**   | ||||
| - **Cristiano**   | ||||
| - **Arsène** | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## 🚀 Objectif | ||||
| Fournir un outil complet pour automatiser la gestion des stocks et des commandes, réduisant les erreurs humaines, améliorant le suivi des livraisons et facilitant la communication avec les fournisseurs. | ||||
		Reference in New Issue
	
	Block a user