forked from sanchezvem/PyroFetes
		
	Compare commits
	
		
			18 Commits
		
	
	
		
			bb5dd63da2
			...
			develop
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4c0e7df9de | |||
| 5506eab8ff | |||
| 15545980af | |||
| dda2240e86 | |||
| a014c6c9f7 | |||
| 2112605cf3 | |||
| 90d685d42c | |||
| 2bcca6f856 | |||
| 6d564c89ff | |||
| bad259e9f5 | |||
| 32dee6eb18 | |||
| b3347fe163 | |||
| 0e74cb40f5 | |||
| 91b4aca2fa | |||
| 1734ec0219 | |||
| 7a8daa6ab8 | |||
| 8f4171a045 | |||
| 8a8a47c99c | 
| @@ -1,7 +1,9 @@ | |||||||
| namespace API.DTO.Brand.Request; | namespace PyroFetes.DTO.Brand.Request | ||||||
|  | { | ||||||
|  |     // DTO pour créer une nouvelle marque | ||||||
|     public class CreateBrandDto |     public class CreateBrandDto | ||||||
|     { |     { | ||||||
|  |         // Nom de la marque | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|      |     } | ||||||
| } | } | ||||||
| @@ -1,8 +1,12 @@ | |||||||
| namespace API.DTO.Brand.Request; | namespace PyroFetes.DTO.Brand.Request | ||||||
|  | { | ||||||
|  |     // DTO pour mettre à jour une marque existante | ||||||
|     public class UpdateBrandDto |     public class UpdateBrandDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de la marque à mettre à jour | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Name { get; set; } |  | ||||||
|  |  | ||||||
|  |         // Nouveau nom de la marque | ||||||
|  |         public string? Name { get; set; } | ||||||
|  |     } | ||||||
| } | } | ||||||
| @@ -1,8 +1,12 @@ | |||||||
| namespace API.DTO.Brand.Response; | namespace API.DTO.Brand.Response | ||||||
|  | { | ||||||
|  |     // DTO pour récupérer les informations d'une marque | ||||||
|     public class GetBrandDto |     public class GetBrandDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de la marque | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Name { get; set; } |  | ||||||
|  |  | ||||||
|  |         // Nom de la marque | ||||||
|  |         public string? Name { get; set; } | ||||||
|  |     } | ||||||
| } | } | ||||||
| @@ -1,7 +1,11 @@ | |||||||
| namespace API.DTO.Classification.Request; | // Définition de l'espace de noms pour les DTO liés à la création de classifications | ||||||
|  | namespace API.DTO.Classification.Request | ||||||
|  | { | ||||||
|  |     // DTO (Data Transfer Object) utilisé pour créer une nouvelle classification | ||||||
|     public class CreateClassificationDto |     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; } |         public string? Label { get; set; } | ||||||
|      |     } | ||||||
| } | } | ||||||
| @@ -1,8 +1,15 @@ | |||||||
| namespace API.DTO.Classification.Request; | // Définition de l'espace de noms pour les DTO liés à la mise à jour de classifications | ||||||
|  | namespace API.DTO.Classification.Request | ||||||
|  | { | ||||||
|  |     // DTO (Data Transfer Object) utilisé pour mettre à jour une classification existante | ||||||
|     public class UpdateClassificationDto |     public class UpdateClassificationDto | ||||||
|     { |     { | ||||||
|  |         // Propriété représentant l'ID unique de la classification à mettre à jour | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Label { 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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO (Data Transfer Object) utilisé pour renvoyer les informations d'une classification | ||||||
|     public class GetClassificationDto |     public class GetClassificationDto | ||||||
|     { |     { | ||||||
|  |         // Propriété représentant l'ID unique de la classification | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Label { 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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour créer une nouvelle couleur | ||||||
|     public class CreateColorDto |     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; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| namespace API.DTO.Color.Request; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour mettre à jour une couleur existante | ||||||
|     public class UpdateColorDto |     public class UpdateColorDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique de la couleur à mettre à jour | ||||||
|         public int Id { get; set; } |         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; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| namespace API.DTO.Color.Response; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour renvoyer les informations d'une couleur | ||||||
|     public class GetColorDto |     public class GetColorDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique de la couleur | ||||||
|         public int Id { get; set; } |         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; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,6 +1,11 @@ | |||||||
| namespace API.DTO.Effect.Request; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour créer un nouvel effet | ||||||
|     public class CreateEffectDto |     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; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| namespace API.DTO.Effect.Request; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour mettre à jour un effet existant | ||||||
|     public class UpdateEffectDto |     public class UpdateEffectDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique de l'effet à mettre à jour | ||||||
|         public int Id { get; set; } |         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; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| namespace API.DTO.Effect.Response; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour renvoyer les informations d'un effet | ||||||
|     public class GetEffectDto |     public class GetEffectDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique de l'effet | ||||||
|         public int Id { get; set; } |         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; } |         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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour créer un nouveau matériau | ||||||
|     public class CreateMaterialDto |     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; } |         public string? Label { get; set; } | ||||||
|     public int Quantity { get; set; } |  | ||||||
|     public int WarehouseId {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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour mettre à jour un matériau existant | ||||||
|     public class UpdateMaterialDto |     public class UpdateMaterialDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique du matériau à mettre à jour | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Label { get; set; } |  | ||||||
|     public int Quantity { get; set; } |  | ||||||
|     public int WarehouseId {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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour renvoyer les informations d'un matériau | ||||||
|     public class GetMaterialDto |     public class GetMaterialDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique du matériau | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Label { get; set; } |  | ||||||
|     public int Quantity { get; set; } |  | ||||||
|     public int WarehouseId {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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour créer un nouveau mouvement | ||||||
|     public class CreateMovementDto |     public class CreateMovementDto | ||||||
|     { |     { | ||||||
|  |         // Date à laquelle le mouvement est enregistré | ||||||
|         public DateTime Date  { get; set; } |         public DateTime Date  { get; set; } | ||||||
|     public DateTime Start {get; set;} |  | ||||||
|     public DateTime Arrival {get; set;} |  | ||||||
|     public int Quantity {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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour mettre à jour un mouvement existant | ||||||
|     public class UpdateMovementDto |     public class UpdateMovementDto | ||||||
|     { |     { | ||||||
|  |         // ID unique du mouvement à mettre à jour | ||||||
|         public int Id { get; set; } |         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;} |  | ||||||
|  |  | ||||||
|  |         // 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; | // 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 | ||||||
|  | { | ||||||
|  |     // DTO utilisé pour renvoyer les informations d'un mouvement | ||||||
|     public class GetMovementDto |     public class GetMovementDto | ||||||
|     { |     { | ||||||
|  |         // ID unique du mouvement | ||||||
|         public int Id { get; set; } |         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;} |  | ||||||
|  |  | ||||||
|  |         // 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; } | ||||||
|  |     } | ||||||
| } | } | ||||||
| @@ -2,25 +2,49 @@ | |||||||
|  |  | ||||||
| namespace PyroFetes.DTO.Product.Request | namespace PyroFetes.DTO.Product.Request | ||||||
| { | { | ||||||
|  |     // DTO utilisé lors de la création d’un produit | ||||||
|     public class CreateProductDto |     public class CreateProductDto | ||||||
|     { |     { | ||||||
|  |         // Référence interne du produit | ||||||
|         public int References { get; set; } |         public int References { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du produit | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Durée de l’effet du produit | ||||||
|         public decimal Duration { get; set; } |         public decimal Duration { get; set; } | ||||||
|  |  | ||||||
|  |         // Calibre du produit | ||||||
|         public decimal Caliber { get; set; } |         public decimal Caliber { get; set; } | ||||||
|  |  | ||||||
|  |         // Numéro d’homologation | ||||||
|         public int ApprovalNumber { get; set; } |         public int ApprovalNumber { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids du produit | ||||||
|         public decimal Weight { get; set; } |         public decimal Weight { get; set; } | ||||||
|  |  | ||||||
|  |         // Matière active (NEC) | ||||||
|         public decimal Nec { get; set; } |         public decimal Nec { get; set; } | ||||||
|  |  | ||||||
|  |         // Prix de vente du produit | ||||||
|         public decimal SellingPrice { get; set; } |         public decimal SellingPrice { get; set; } | ||||||
|  |  | ||||||
|  |         // Image associée au produit (URL ou chemin) | ||||||
|         public string? Image { get; set; } |         public string? Image { get; set; } | ||||||
|  |  | ||||||
|  |         // Lien vers une ressource externe (vidéo, fiche, etc.) | ||||||
|         public string? Link { get; set; } |         public string? Link { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant de la classification du produit | ||||||
|         public int ClassificationId { get; set; } |         public int ClassificationId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant de la catégorie du produit | ||||||
|         public int ProductCategoryId { get; set; } |         public int ProductCategoryId { get; set; } | ||||||
|  |  | ||||||
|         // Liste des fournisseurs liés au produit |         // Liste des fournisseurs liés au produit venant du DTO ProductSupplierPriceDto | ||||||
|         public List<ProductSupplierPriceDto>? Suppliers { get; set; } |         public List<ProductSupplierPriceDto>? Suppliers { get; set; } | ||||||
|  |  | ||||||
|         // Liste des entrepôts liés au produit |         // Liste des entrepôts liés au produit venant du DTO CreateProductWarehouseDto | ||||||
|         public List<CreateProductWarehouseDto>? Warehouses { get; set; } |         public List<CreateProductWarehouseDto>? Warehouses { get; set; } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -2,26 +2,52 @@ | |||||||
|  |  | ||||||
| namespace PyroFetes.DTO.Product.Request | namespace PyroFetes.DTO.Product.Request | ||||||
| { | { | ||||||
|  |     // DTO utilisé pour la mise à jour d’un produit existant | ||||||
|     public class UpdateProductDto |     public class UpdateProductDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique du produit à modifier | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Référence interne du produit | ||||||
|         public int References { get; set; } |         public int References { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du produit | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Durée de l’effet du produit | ||||||
|         public decimal Duration { get; set; } |         public decimal Duration { get; set; } | ||||||
|  |  | ||||||
|  |         // Calibre du produit | ||||||
|         public decimal Caliber { get; set; } |         public decimal Caliber { get; set; } | ||||||
|  |  | ||||||
|  |         // Numéro d’homologation | ||||||
|         public int ApprovalNumber { get; set; } |         public int ApprovalNumber { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids du produit | ||||||
|         public decimal Weight { get; set; } |         public decimal Weight { get; set; } | ||||||
|  |  | ||||||
|  |         // Matière active (NEC) | ||||||
|         public decimal Nec { get; set; } |         public decimal Nec { get; set; } | ||||||
|  |  | ||||||
|  |         // Prix de vente du produit | ||||||
|         public decimal SellingPrice { get; set; } |         public decimal SellingPrice { get; set; } | ||||||
|  |  | ||||||
|  |         // Image associée au produit (URL ou chemin) | ||||||
|         public string? Image { get; set; } |         public string? Image { get; set; } | ||||||
|  |  | ||||||
|  |         // Lien vers une ressource externe (fiche, vidéo, etc.) | ||||||
|         public string? Link { get; set; } |         public string? Link { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant de la classification du produit | ||||||
|         public int ClassificationId { get; set; } |         public int ClassificationId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant de la catégorie du produit | ||||||
|         public int ProductCategoryId { get; set; } |         public int ProductCategoryId { get; set; } | ||||||
|  |  | ||||||
|         // Liste des fournisseurs associés |         // Liste des fournisseurs associés venant du DTO ProductSupplierPriceDto | ||||||
|         public List<ProductSupplierPriceDto> Suppliers { get; set; } = new(); |         public List<ProductSupplierPriceDto> Suppliers { get; set; } = new(); | ||||||
|  |  | ||||||
|         // Liste des entrepôts associés |         // Liste des entrepôts associés venant du DTO UpdateProductWarehouseDto | ||||||
|         public List<UpdateProductWarehouseDto> Warehouses { get; set; } = new(); |         public List<UpdateProductWarehouseDto> Warehouses { get; set; } = new(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,29 +1,54 @@ | |||||||
| using PyroFetes.DTO.Product.Request; | using PyroFetes.DTO.Product.Request; | ||||||
| using PyroFetes.DTO.Product.Request; |  | ||||||
| using PyroFetes.DTO.Product.Response; | using PyroFetes.DTO.Product.Response; | ||||||
|  |  | ||||||
| namespace PyroFetes.DTO.Product.Response | namespace PyroFetes.DTO.Product.Response | ||||||
| { | { | ||||||
|  |     // DTO utilisé pour renvoyer les informations complètes d’un produit | ||||||
|     public class GetProductDto |     public class GetProductDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant unique du produit | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Référence interne du produit | ||||||
|         public int Reference { get; set; } |         public int Reference { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du produit | ||||||
|         public string? Name { get; set; } |         public string? Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Durée de l’effet du produit | ||||||
|         public decimal Duration { get; set; } |         public decimal Duration { get; set; } | ||||||
|  |  | ||||||
|  |         // Calibre du produit | ||||||
|         public decimal Caliber { get; set; } |         public decimal Caliber { get; set; } | ||||||
|  |  | ||||||
|  |         // Numéro d’homologation | ||||||
|         public int ApprovalNumber { get; set; } |         public int ApprovalNumber { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids du produit | ||||||
|         public decimal Weight { get; set; } |         public decimal Weight { get; set; } | ||||||
|  |  | ||||||
|  |         // Matière active (NEC) | ||||||
|         public decimal Nec { get; set; } |         public decimal Nec { get; set; } | ||||||
|  |  | ||||||
|  |         // Prix de vente du produit | ||||||
|         public decimal SellingPrice { get; set; } |         public decimal SellingPrice { get; set; } | ||||||
|  |  | ||||||
|  |         // Image du produit (URL ou chemin) | ||||||
|         public string? Image { get; set; } |         public string? Image { get; set; } | ||||||
|  |  | ||||||
|  |         // Lien externe vers plus d’informations (fiche, vidéo, etc.) | ||||||
|         public string? Link { get; set; } |         public string? Link { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant de la classification du produit | ||||||
|         public int ClassificationId { get; set; } |         public int ClassificationId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant de la catégorie du produit | ||||||
|         public int ProductCategoryId { get; set; } |         public int ProductCategoryId { get; set; } | ||||||
|  |  | ||||||
|         // Fournisseurs liés |         // Fournisseurs liés venant du DTO ProductSupplierPriceDto | ||||||
|         public List<ProductSupplierPriceDto> Suppliers { get; set; } = new(); |         public List<ProductSupplierPriceDto> Suppliers { get; set; } = new(); | ||||||
|  |  | ||||||
|         // Entrepôts liés |         // Entrepôts liés venant du DTO ProductWarehouseDto | ||||||
|         public List<GetProductWarehouseDto> Warehouses { get; set; } = new(); |         public List<GetProductWarehouseDto> Warehouses { get; set; } = new(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,6 +1,9 @@ | |||||||
| namespace API.DTO.ProductCategory.Request; | namespace API.DTO.ProductCategory.Request | ||||||
|  | { | ||||||
|  |     // DTO pour créer une catégorie de produit | ||||||
|     public class CreateProductCategoryDto |     public class CreateProductCategoryDto | ||||||
|     { |     { | ||||||
|  |         // Nom de la catégorie | ||||||
|         public string? Label { get; set; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,12 @@ | |||||||
| namespace API.DTO.ProductCategory.Request; | namespace API.DTO.ProductCategory.Request | ||||||
|  | { | ||||||
|  |     // DTO pour mettre à jour une catégorie de produit | ||||||
|     public class UpdateProductCategoryDto |     public class UpdateProductCategoryDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de la catégorie | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom de la catégorie | ||||||
|         public string? Label { get; set; } |         public string? Label { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,8 +1,12 @@ | |||||||
| namespace API.DTO.ProductCategory.Response; | namespace API.DTO.ProductCategory.Response | ||||||
|  | { | ||||||
|  |     // DTO pour récupérer une catégorie de produit | ||||||
|     public class GetProductCategoryDto |     public class GetProductCategoryDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de la catégorie | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|     public string? Label { 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; } | ||||||
|  | } | ||||||
| @@ -1,11 +1,18 @@ | |||||||
| namespace PyroFetes.DTO.Product.Response | namespace PyroFetes.DTO.Product.Response | ||||||
| { | { | ||||||
| // DTO pour la lecture des fournisseurs liés à un produit |     // DTO utilisé pour renvoyer les informations d’un fournisseur lié à un produit | ||||||
|     public class GetProductSupplierDto |     public class GetProductSupplierDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du produit concerné | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant du fournisseur | ||||||
|         public int SupplierId { get; set; } |         public int SupplierId { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du fournisseur | ||||||
|         public string SupplierName { get; set; } = string.Empty; |         public string SupplierName { get; set; } = string.Empty; | ||||||
|  |  | ||||||
|  |         // Prix de vente du produit fourni par ce fournisseur | ||||||
|         public decimal SellingPrice { get; set; } |         public decimal SellingPrice { get; set; } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,17 +1,28 @@ | |||||||
| namespace PyroFetes.DTO.Product.Request | namespace PyroFetes.DTO.Product.Request | ||||||
| { | { | ||||||
|     // DTO utilisé pour créer ou mettre à jour la relation Product <-> Warehouse |     // DTO utilisé lors de la création d’une relation entre un produit et un entrepôt | ||||||
|     public class CreateProductWarehouseDto |     public class CreateProductWarehouseDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de l'entrepôt concerné | ||||||
|         public int WarehouseId { get; set; } |         public int WarehouseId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant du produit associé à cet entrepôt | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Quantité du produit disponible dans cet entrepôt | ||||||
|         public int Quantity { get; set; } |         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 |     public class UpdateProductWarehouseDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de l'entrepôt concerné | ||||||
|         public int WarehouseId { get; set; } |         public int WarehouseId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant du produit associé à cet entrepôt | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Nouvelle quantité du produit dans cet entrepôt | ||||||
|         public int Quantity { get; set; } |         public int Quantity { get; set; } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,11 +1,18 @@ | |||||||
| namespace PyroFetes.DTO.Product.Response | namespace PyroFetes.DTO.Product.Response | ||||||
| { | { | ||||||
|     // DTO pour la lecture des entrepôts liés à un produit |     // DTO utilisé pour renvoyer les informations d’un entrepôt lié à un produit | ||||||
|     public class GetProductWarehouseDto |     public class GetProductWarehouseDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de l'entrepôt | ||||||
|         public int WarehouseId { get; set; } |         public int WarehouseId { get; set; } | ||||||
|  |  | ||||||
|  |         // Identifiant du produit associé à cet entrepôt | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom de l'entrepôt (utile pour l’affichage) | ||||||
|         public string WarehouseName { get; set; } = string.Empty; |         public string WarehouseName { get; set; } = string.Empty; | ||||||
|  |  | ||||||
|  |         // Quantité du produit stockée dans cet entrepôt | ||||||
|         public int Quantity { get; set; } |         public int Quantity { get; set; } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,20 +1,37 @@ | |||||||
| namespace PyroFetes.DTO.Supplier.Request; | namespace PyroFetes.DTO.Supplier.Request | ||||||
|  | { | ||||||
|  |     // DTO pour créer un nouveau fournisseur | ||||||
|     public class CreateSupplierDto |     public class CreateSupplierDto | ||||||
|     { |     { | ||||||
|  |         // Nom du fournisseur | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Email du fournisseur | ||||||
|         public string Email { get; set; } |         public string Email { get; set; } | ||||||
|  |  | ||||||
|  |         // Numéro de téléphone du fournisseur | ||||||
|         public string PhoneNumber { get; set; }  |         public string PhoneNumber { get; set; }  | ||||||
|  |  | ||||||
|  |         // Adresse du fournisseur | ||||||
|         public string Adress { get; set; } |         public string Adress { get; set; } | ||||||
|  |  | ||||||
|  |         // Code postal de l'adresse | ||||||
|         public int ZipCode { get; set; } |         public int ZipCode { get; set; } | ||||||
|  |  | ||||||
|  |         // Ville de l'adresse | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|  |  | ||||||
|     // Produits que ce fournisseur fournit |         // Liste des produits fournis par ce fournisseur dans la classe SupplierProductPriceDto | ||||||
|         public List<SupplierProductPriceDto>? Products { get; set; } |         public List<SupplierProductPriceDto>? Products { get; set; } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // DTO pour relier un produit et son prix à un fournisseur | ||||||
|     public class SupplierProductPriceDto |     public class SupplierProductPriceDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du produit fourni | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Prix de vente du produit par ce fournisseur | ||||||
|         public decimal SellingPrice { get; set; } |         public decimal SellingPrice { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,14 +1,30 @@ | |||||||
| namespace PyroFetes.DTO.Supplier.Request; | namespace PyroFetes.DTO.Supplier.Request | ||||||
|  | { | ||||||
|  |     // DTO pour mettre à jour un fournisseur existant | ||||||
|     public class UpdateSupplierDto |     public class UpdateSupplierDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du fournisseur à mettre à jour | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du fournisseur | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Email du fournisseur | ||||||
|         public string Email { get; set; } |         public string Email { get; set; } | ||||||
|  |  | ||||||
|  |         // Numéro de téléphone du fournisseur | ||||||
|         public string PhoneNumber { get; set; }  |         public string PhoneNumber { get; set; }  | ||||||
|  |  | ||||||
|  |         // Adresse du fournisseur | ||||||
|         public string Adress { get; set; } |         public string Adress { get; set; } | ||||||
|  |  | ||||||
|  |         // Code postal de l'adresse | ||||||
|         public int ZipCode { get; set; } |         public int ZipCode { get; set; } | ||||||
|  |  | ||||||
|  |         // Ville de l'adresse | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|  |  | ||||||
|  |         // Liste des produits fournis par ce fournisseur relié à la classe SupplierProductPriceDto | ||||||
|         public List<SupplierProductPriceDto>? Products { get; set; } |         public List<SupplierProductPriceDto>? Products { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,24 +1,45 @@ | |||||||
| using PyroFetes.DTO.Supplier.Request; | using PyroFetes.DTO.Supplier.Request; | ||||||
|  |  | ||||||
| namespace PyroFetes.DTO.Supplier.Response; | namespace PyroFetes.DTO.Supplier.Response | ||||||
|  | { | ||||||
|  |     // DTO pour récupérer les informations d'un fournisseur | ||||||
|     public class GetSupplierDto |     public class GetSupplierDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du fournisseur | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du fournisseur | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Email du fournisseur | ||||||
|         public string Email { get; set; } |         public string Email { get; set; } | ||||||
|  |  | ||||||
|  |         // Numéro de téléphone | ||||||
|         public string PhoneNumber { get; set; }  |         public string PhoneNumber { get; set; }  | ||||||
|  |  | ||||||
|  |         // Adresse du fournisseur | ||||||
|         public string Adress { get; set; } |         public string Adress { get; set; } | ||||||
|  |  | ||||||
|  |         // Code postal | ||||||
|         public int ZipCode { get; set; } |         public int ZipCode { get; set; } | ||||||
|  |  | ||||||
|  |         // Ville | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|  |  | ||||||
|     // Liste des produits liés avec leur prix fournisseur |         // Liste des produits fournis par la classe SupplierProductPriceDto | ||||||
|     public List<SupplierProductPriceDto> Products { get; set; } |         public List<SupplierProductPriceDto> Products { get; set; } = new(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // DTO pour les détails d'un produit lié à un fournisseur | ||||||
|     public class GetSupplierProductDto |     public class GetSupplierProductDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du produit | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du produit | ||||||
|         public string ProductName { get; set; } = string.Empty; |         public string ProductName { get; set; } = string.Empty; | ||||||
|  |  | ||||||
|  |         // Prix de vente fourni par le fournisseur | ||||||
|         public decimal SellingPrice { get; set; } |         public decimal SellingPrice { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,21 +1,40 @@ | |||||||
| namespace API.DTO.Warehouse.Request; | namespace API.DTO.Warehouse.Request | ||||||
|  | { | ||||||
|  |     // DTO pour créer un entrepôt | ||||||
|     public class CreateWarehouseDto |     public class CreateWarehouseDto | ||||||
|     { |     { | ||||||
|  |         // Nom de l'entrepôt | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids maximal que l'entrepôt peut contenir | ||||||
|         public int MaxWeight { get; set; } |         public int MaxWeight { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids actuel stocké | ||||||
|         public int Current { get; set; } |         public int Current { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids minimal souhaité | ||||||
|         public int MinWeight { get; set; } |         public int MinWeight { get; set; } | ||||||
|  |  | ||||||
|  |         // Adresse de l'entrepôt | ||||||
|         public string Adress { get; set; } |         public string Adress { get; set; } | ||||||
|  |  | ||||||
|  |         // Code postal | ||||||
|         public int ZipCode { get; set; } |         public int ZipCode { get; set; } | ||||||
|  |  | ||||||
|  |         // Ville | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|   |   | ||||||
|     // Liste des produits à stocker dans cet entrepôt |         // Liste des produits à stocker dans cet entrepôt venant de la classe en dessous | ||||||
|         public List<CreateWarehouseProductDto>? Products { get; set; } |         public List<CreateWarehouseProductDto>? Products { get; set; } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // DTO pour associer un produit à un entrepôt | ||||||
|     public class CreateWarehouseProductDto |     public class CreateWarehouseProductDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du produit | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Quantité du produit dans l'entrepôt | ||||||
|         public int Quantity { get; set; } |         public int Quantity { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,21 +1,43 @@ | |||||||
| namespace API.DTO.Warehouse.Request; | namespace API.DTO.Warehouse.Request | ||||||
|  | { | ||||||
|  |     // DTO pour mettre à jour un entrepôt | ||||||
|     public class UpdateWarehouseDto |     public class UpdateWarehouseDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de l'entrepôt à mettre à jour | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom de l'entrepôt | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids maximal que l'entrepôt peut contenir | ||||||
|         public int MaxWeight { get; set; } |         public int MaxWeight { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids actuel stocké | ||||||
|         public int Current { get; set; } |         public int Current { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids minimal souhaité | ||||||
|         public int MinWeight { get; set; } |         public int MinWeight { get; set; } | ||||||
|  |  | ||||||
|  |         // Adresse de l'entrepôt | ||||||
|         public string Adress { get; set; } |         public string Adress { get; set; } | ||||||
|  |  | ||||||
|  |         // Code postal | ||||||
|         public int ZipCode { get; set; } |         public int ZipCode { get; set; } | ||||||
|  |  | ||||||
|  |         // Ville | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|  |  | ||||||
|  |         // Liste des produits à mettre à jour dans cet entrepôt | ||||||
|         public List<UpdateWarehouseProductDto>? Products { get; set; } |         public List<UpdateWarehouseProductDto>? Products { get; set; } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // DTO pour mettre à jour la quantité d'un produit dans un entrepôt | ||||||
|     public class UpdateWarehouseProductDto |     public class UpdateWarehouseProductDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du produit | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Nouvelle quantité du produit dans l'entrepôt | ||||||
|         public int Quantity { get; set; } |         public int Quantity { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,22 +1,46 @@ | |||||||
| namespace API.DTO.Warehouse.Response; | namespace API.DTO.Warehouse.Response | ||||||
|  | { | ||||||
|  |     // DTO pour la lecture d'un entrepôt | ||||||
|     public class GetWarehouseDto |     public class GetWarehouseDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant de l'entrepôt | ||||||
|         public int Id { get; set; } |         public int Id { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom de l'entrepôt | ||||||
|         public string Name { get; set; } |         public string Name { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids maximal que l'entrepôt peut contenir | ||||||
|         public int MaxWeight { get; set; } |         public int MaxWeight { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids actuellement stocké | ||||||
|         public int Current { get; set; } |         public int Current { get; set; } | ||||||
|  |  | ||||||
|  |         // Poids minimal souhaité | ||||||
|         public int MinWeight { get; set; } |         public int MinWeight { get; set; } | ||||||
|  |  | ||||||
|  |         // Adresse de l'entrepôt | ||||||
|         public string Adress { get; set; } |         public string Adress { get; set; } | ||||||
|  |  | ||||||
|  |         // Code postal | ||||||
|         public int ZipCode { get; set; } |         public int ZipCode { get; set; } | ||||||
|  |  | ||||||
|  |         // Ville | ||||||
|         public string City { get; set; } |         public string City { get; set; } | ||||||
|  |  | ||||||
|  |         // Liste des produits stockés dans l'entrepôt | ||||||
|         public List<WarehouseProductDto>? Products { get; set; } |         public List<WarehouseProductDto>? Products { get; set; } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // DTO pour la lecture d'un produit dans un entrepôt | ||||||
|     public class WarehouseProductDto |     public class WarehouseProductDto | ||||||
|     { |     { | ||||||
|  |         // Identifiant du produit | ||||||
|         public int ProductId { get; set; } |         public int ProductId { get; set; } | ||||||
|  |  | ||||||
|  |         // Nom du produit | ||||||
|         public string? ProductName { get; set; } |         public string? ProductName { get; set; } | ||||||
|  |  | ||||||
|  |         // Quantité du produit dans l'entrepôt | ||||||
|         public int Quantity { get; set; } |         public int Quantity { get; set; } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| using API.DTO.Brand.Request; |  | ||||||
| using API.DTO.Brand.Response; | using API.DTO.Brand.Response; | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
|  | using PyroFetes.DTO.Brand.Request; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Brand; | namespace PyroFetes.Endpoints.Brand; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| using API.DTO.Brand.Request; |  | ||||||
| using API.DTO.Brand.Response; | using API.DTO.Brand.Response; | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
|  | using PyroFetes.DTO.Brand.Request; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Brand; | namespace PyroFetes.Endpoints.Brand; | ||||||
|  |  | ||||||
| @@ -8,7 +8,7 @@ public class UpdateBrandEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Put("/api/brands"); |         Put("/api/brands/{Id}");  | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|   | |||||||
| @@ -1,26 +1,27 @@ | |||||||
| using API.DTO.Color.Request; | using API.DTO.Color.Request; | ||||||
| using API.DTO.Color.Response; | using API.DTO.Color.Response; | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
|  | using PyroFetes; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Color; | namespace API.Endpoints.Color; | ||||||
|  |  | ||||||
| public class CreateColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint<CreateColorDto, GetColorDto> | 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() |     public override void Configure() //Configuration de l'endpoint | ||||||
|     { |     { | ||||||
|         Post("/color/create"); |         Post("Api/colors"); //Création d'un endpoint pour créer une couleur avec les données de CreateColorDto | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); //Laisser passer les requêtes non authentifiées | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public override async Task HandleAsync(CreateColorDto req, CancellationToken ct) |     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  | ||||||
|     { |     { | ||||||
|         Models.Color color = new() |         PyroFetes.Models.Color color = new() | ||||||
|         { |         { | ||||||
|             Label = req.Label, |             Label = req.Label, | ||||||
|         }; |         }; | ||||||
|          |          | ||||||
|         pyrofetesdbcontext.Colors.Add(color); |         pyroFetesDbContext.Colors.Add(color); | ||||||
|         await pyrofetesdbcontext.SaveChangesAsync(ct); |         await pyroFetesDbContext.SaveChangesAsync(ct); | ||||||
|         Console.WriteLine("Added Color"); |         Console.WriteLine("Added Color"); | ||||||
|  |  | ||||||
|         GetColorDto responseDto = new() |         GetColorDto responseDto = new() | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ public class DeleteColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Delete("/colors/{@id}", x => new { x.Id }); |         Delete("Api/colors/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ public class GetAllColorsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpo | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Get("/colors"); |         Get("Api/colors"); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ public class GetColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint< | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Get("/colors/{@id}", x => new { x.Id}); |         Get("Api/colors/{@id}", x => new { x.Id}); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ public class UpdateColorEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Put("/colors/{@id}", x => new { x.Id }); |         Put("Api/colors/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ public class CreateEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpo | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Post("/effect/create"); |         Post("Api/effects"); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ public class DeleteEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpo | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Delete("/effects/{@id}", x => new { x.Id }); |         Delete("Api/effects/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ public class GetAllEffectsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endp | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Get("/effects"); |         Get("Api/effects"); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ public class GetEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoint | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Get("/effect/{@id}", x => new { x.Id }); |         Get("Api/effects/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ public class UpdateEffectEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpo | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Put("/effect/{@id}", x => new { x.Id }); |         Put("Api/effects/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										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); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -8,7 +8,7 @@ public class CreateMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Post("/material/create"); |         Post("Api/materials"); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ public class GetAllMaterialsEndpoint(PyroFetesDbContext pyrofetesdbcontext) : En | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Get("/material"); |         Get("Api/materials"); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ public class GetMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : Endpoi | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Get("/material/{@id}", x => new { x.Id }); |         Get("Api/materials/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ public class UpdateMaterialEndpoint(PyroFetesDbContext pyrofetesdbcontext) : End | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         Put("/material/{@id}", x => new { x.Id }); |         Put("Api/materials/{@id}", x => new { x.Id }); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,8 +2,6 @@ | |||||||
| using PyroFetes.DTO.Product.Response; | using PyroFetes.DTO.Product.Response; | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| using PyroFetes.DTO.Product.Request; |  | ||||||
| using PyroFetes.DTO.Product.Response; |  | ||||||
| using PyroFetes.Models; | using PyroFetes.Models; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Product; | namespace PyroFetes.Endpoints.Product; | ||||||
| @@ -21,14 +19,13 @@ public class CreateProductEndpoint(PyroFetesDbContext db) | |||||||
|     { |     { | ||||||
|         var product = new Models.Product |         var product = new Models.Product | ||||||
|         { |         { | ||||||
|             References = req.References, |             Reference = req.References.ToString(), | ||||||
|             Name = req.Name!, |             Name = req.Name!, | ||||||
|             Duration = req.Duration, |             Duration = req.Duration, | ||||||
|             Caliber = req.Caliber, |             Caliber = req.Caliber, | ||||||
|             ApprovalNumber = req.ApprovalNumber, |             ApprovalNumber = req.ApprovalNumber, | ||||||
|             Weight = req.Weight, |             Weight = req.Weight, | ||||||
|             Nec = req.Nec, |             Nec = req.Nec, | ||||||
|             SellingPrice = req.SellingPrice, |  | ||||||
|             Image = req.Image!, |             Image = req.Image!, | ||||||
|             Link = req.Link!, |             Link = req.Link!, | ||||||
|             ProductCategoryId = req.ProductCategoryId, |             ProductCategoryId = req.ProductCategoryId, | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| using PyroFetes.DTO.Product.Request; | using PyroFetes.DTO.Product.Response; | ||||||
| using PyroFetes.DTO.Product.Response; |  | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| using PyroFetes.DTO.Product.Request; | using PyroFetes.DTO.Product.Request; | ||||||
| using PyroFetes.DTO.Product.Response; |  | ||||||
| using PyroFetes.Models; | using PyroFetes.Models; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Product; | namespace PyroFetes.Endpoints.Product; | ||||||
| @@ -29,14 +27,16 @@ public class GetAllProductsEndpoint(PyroFetesDbContext db) | |||||||
|         var responseDto = products.Select(p => new GetProductDto |         var responseDto = products.Select(p => new GetProductDto | ||||||
|         { |         { | ||||||
|             Id = p.Id, |             Id = p.Id, | ||||||
|             Reference = p.References, |             // Le modèle Product contient "Reference" (string) — pas "References" (int) | ||||||
|  |             Reference = int.TryParse(p.Reference, out var refInt) ? refInt : 0, | ||||||
|             Name = p.Name, |             Name = p.Name, | ||||||
|             Duration = p.Duration, |             Duration = p.Duration, | ||||||
|             Caliber = p.Caliber, |             Caliber = p.Caliber, | ||||||
|             ApprovalNumber = p.ApprovalNumber, |             ApprovalNumber = p.ApprovalNumber, | ||||||
|             Weight = p.Weight, |             Weight = p.Weight, | ||||||
|             Nec = p.Nec, |             Nec = p.Nec, | ||||||
|             SellingPrice = p.SellingPrice, |             // 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, |             Image = p.Image, | ||||||
|             Link = p.Link, |             Link = p.Link, | ||||||
|             ClassificationId = p.ClassificationId, |             ClassificationId = p.ClassificationId, | ||||||
| @@ -49,7 +49,7 @@ public class GetAllProductsEndpoint(PyroFetesDbContext db) | |||||||
|                 SellingPrice = pr.SellingPrice |                 SellingPrice = pr.SellingPrice | ||||||
|             }).ToList(), |             }).ToList(), | ||||||
|  |  | ||||||
|             // Liste des entrepôts via WarehouseProduct |             // Liste des entrepôts liés via WarehouseProduct | ||||||
|             Warehouses = p.WarehouseProducts.Select(wp => new GetProductWarehouseDto |             Warehouses = p.WarehouseProducts.Select(wp => new GetProductWarehouseDto | ||||||
|             { |             { | ||||||
|                 WarehouseId = wp.WarehouseId, |                 WarehouseId = wp.WarehouseId, | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| using PyroFetes.DTO.Product.Request; | using PyroFetes.DTO.Product.Response; | ||||||
| using PyroFetes.DTO.Product.Response; |  | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| using PyroFetes.DTO.Product.Request; | using PyroFetes.DTO.Product.Request; | ||||||
| using PyroFetes.DTO.Product.Response; |  | ||||||
| using PyroFetes.Models; | using PyroFetes.Models; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Product; | namespace PyroFetes.Endpoints.Product; | ||||||
| @@ -41,14 +39,20 @@ public class GetProductEndpoint(PyroFetesDbContext db) | |||||||
|         var responseDto = new GetProductDto |         var responseDto = new GetProductDto | ||||||
|         { |         { | ||||||
|             Id = product.Id, |             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, |             Name = product.Name, | ||||||
|             Duration = product.Duration, |             Duration = product.Duration, | ||||||
|             Caliber = product.Caliber, |             Caliber = product.Caliber, | ||||||
|             ApprovalNumber = product.ApprovalNumber, |             ApprovalNumber = product.ApprovalNumber, | ||||||
|             Weight = product.Weight, |             Weight = product.Weight, | ||||||
|             Nec = product.Nec, |             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, |             Image = product.Image, | ||||||
|             Link = product.Link, |             Link = product.Link, | ||||||
|             ClassificationId = product.ClassificationId, |             ClassificationId = product.ClassificationId, | ||||||
|   | |||||||
| @@ -2,8 +2,6 @@ | |||||||
| using PyroFetes.DTO.Product.Response; | using PyroFetes.DTO.Product.Response; | ||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using Microsoft.EntityFrameworkCore; | using Microsoft.EntityFrameworkCore; | ||||||
| using PyroFetes.DTO.Product.Request; |  | ||||||
| using PyroFetes.DTO.Product.Response; |  | ||||||
| using PyroFetes.Models; | using PyroFetes.Models; | ||||||
|  |  | ||||||
| namespace PyroFetes.Endpoints.Product; | namespace PyroFetes.Endpoints.Product; | ||||||
| @@ -37,21 +35,19 @@ public class UpdateProductEndpoint(PyroFetesDbContext db) | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Mise à jour des propriétés principales du produit |         // Mise à jour des propriétés principales du produit | ||||||
|         product.References = req.References; |         product.Reference = req.References.ToString(); // Converti int → string | ||||||
|         product.Name = req.Name; |         product.Name = req.Name; | ||||||
|         product.Duration = req.Duration; |         product.Duration = req.Duration; | ||||||
|         product.Caliber = req.Caliber; |         product.Caliber = req.Caliber; | ||||||
|         product.ApprovalNumber = req.ApprovalNumber; |         product.ApprovalNumber = req.ApprovalNumber; | ||||||
|         product.Weight = req.Weight; |         product.Weight = req.Weight; | ||||||
|         product.Nec = req.Nec; |         product.Nec = req.Nec; | ||||||
|         product.SellingPrice = req.SellingPrice; |  | ||||||
|         product.Image = req.Image; |         product.Image = req.Image; | ||||||
|         product.Link = req.Link; |         product.Link = req.Link; | ||||||
|         product.ClassificationId = req.ClassificationId; |         product.ClassificationId = req.ClassificationId; | ||||||
|         product.ProductCategoryId = req.ProductCategoryId; |         product.ProductCategoryId = req.ProductCategoryId; | ||||||
|  |  | ||||||
|         // Mise à jour des prix fournisseurs associés |         // Mise à jour des prix fournisseurs associés | ||||||
|         // On supprime les anciens enregistrements pour les remplacer |  | ||||||
|         db.Prices.RemoveRange(product.Prices); |         db.Prices.RemoveRange(product.Prices); | ||||||
|         foreach (var s in req.Suppliers) |         foreach (var s in req.Suppliers) | ||||||
|         { |         { | ||||||
| @@ -64,7 +60,6 @@ public class UpdateProductEndpoint(PyroFetesDbContext db) | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Mise à jour des entrepôts associés |         // Mise à jour des entrepôts associés | ||||||
|         // On supprime les anciens liens avant d'ajouter les nouveaux |  | ||||||
|         db.WarehouseProducts.RemoveRange(product.WarehouseProducts); |         db.WarehouseProducts.RemoveRange(product.WarehouseProducts); | ||||||
|         foreach (var w in req.Warehouses) |         foreach (var w in req.Warehouses) | ||||||
|         { |         { | ||||||
| @@ -76,44 +71,41 @@ public class UpdateProductEndpoint(PyroFetesDbContext db) | |||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Sauvegarde des modifications dans la base de données |  | ||||||
|         await db.SaveChangesAsync(ct); |         await db.SaveChangesAsync(ct); | ||||||
|  |  | ||||||
|         // Construction de la réponse renvoyée au client |         // Construction de la réponse renvoyée au client | ||||||
|         // On reconstruit les listes Suppliers et Warehouses au bon format de DTO |  | ||||||
|         var response = new GetProductDto |         var response = new GetProductDto | ||||||
|         { |         { | ||||||
|             Id = product.Id, |             Id = product.Id, | ||||||
|             Reference = req.References, |             Reference = req.References, // DTO garde int pour cohérence | ||||||
|             Name = req.Name, |             Name = req.Name, | ||||||
|             Duration = req.Duration, |             Duration = req.Duration, | ||||||
|             Caliber = req.Caliber, |             Caliber = req.Caliber, | ||||||
|             ApprovalNumber = req.ApprovalNumber, |             ApprovalNumber = req.ApprovalNumber, | ||||||
|             Weight = req.Weight, |             Weight = req.Weight, | ||||||
|             Nec = req.Nec, |             Nec = req.Nec, | ||||||
|             SellingPrice = req.SellingPrice, |             // Le prix de vente est pris depuis Prices | ||||||
|  |             SellingPrice = req.Suppliers.FirstOrDefault()?.SellingPrice ?? 0, | ||||||
|             Image = req.Image, |             Image = req.Image, | ||||||
|             Link = req.Link, |             Link = req.Link, | ||||||
|             ClassificationId = req.ClassificationId, |             ClassificationId = req.ClassificationId, | ||||||
|             ProductCategoryId = req.ProductCategoryId, |             ProductCategoryId = req.ProductCategoryId, | ||||||
|  |  | ||||||
|             // Mapping des fournisseurs pour la réponse |  | ||||||
|             Suppliers = req.Suppliers.Select(s => new ProductSupplierPriceDto |             Suppliers = req.Suppliers.Select(s => new ProductSupplierPriceDto | ||||||
|             { |             { | ||||||
|                 SupplierId = s.SupplierId, |                 SupplierId = s.SupplierId, | ||||||
|                 SellingPrice = s.SellingPrice |                 SellingPrice = s.SellingPrice | ||||||
|             }).ToList(), |             }).ToList(), | ||||||
|  |  | ||||||
|             // Mapping des entrepôts pour la réponse |  | ||||||
|             Warehouses = req.Warehouses.Select(w => new GetProductWarehouseDto |             Warehouses = req.Warehouses.Select(w => new GetProductWarehouseDto | ||||||
|             { |             { | ||||||
|                 WarehouseId = w.WarehouseId, |                 WarehouseId = w.WarehouseId, | ||||||
|                 Quantity = w.Quantity, |                 Quantity = w.Quantity, | ||||||
|                 WarehouseName = db.Warehouses.FirstOrDefault(x => x.Id == w.WarehouseId)?.Name ?? string.Empty |                 WarehouseName = db.Warehouses | ||||||
|  |                     .FirstOrDefault(x => x.Id == w.WarehouseId)?.Name ?? string.Empty | ||||||
|             }).ToList() |             }).ToList() | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         // Envoi de la réponse HTTP 200 avec les données du produit mis à jour |  | ||||||
|         await Send.OkAsync(response, ct); |         await Send.OkAsync(response, ct); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -13,11 +13,9 @@ public class DeleteWarehouseEndpoint(PyroFetesDbContext db) : Endpoint<DeleteWar | |||||||
| { | { | ||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         // L’annotation correcte du paramètre est {id}, pas {@id} |         Delete("/api/warehouse/{id}"); | ||||||
|         Delete("/api/warehouse/{@id}", x => new { x.Id }); |  | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public override async Task HandleAsync(DeleteWarehouseRequest req, CancellationToken ct) |     public override async Task HandleAsync(DeleteWarehouseRequest req, CancellationToken ct) | ||||||
|     { |     { | ||||||
|         // On charge aussi les WarehouseProducts liés pour les supprimer proprement |         // On charge aussi les WarehouseProducts liés pour les supprimer proprement | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ public class GetWarehouseEndpoint(PyroFetesDbContext db) | |||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         // Pas de "@id" ici, juste {id} |         // Pas de "@id" ici, juste {id} | ||||||
|         Get("/api/warehouses/{@id}", x => new { x.Id }); |         Get("/api/warehouses/{Id}"); | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ public class UpdateWarehouseEndpoint(PyroFetesDbContext db) | |||||||
|     public override void Configure() |     public override void Configure() | ||||||
|     { |     { | ||||||
|         // Utilise {id} plutôt que {@id} |         // Utilise {id} plutôt que {@id} | ||||||
|         Put("/api/warehouses/{@id}", x => new { x.Id }); |         Put("/api/warehouses/{Id}");        | ||||||
|         AllowAnonymous(); |         AllowAnonymous(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										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 |     public class Product | ||||||
|     { |     { | ||||||
|         [Key] public int Id { get; set; } |         [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, MaxLength(100)] public string? Name { get; set; } | ||||||
|         [Required] public decimal Duration {get; set;}  |         [Required] public decimal Duration {get; set;}  | ||||||
|         [Required] public decimal Caliber { get; set; } |         [Required] public decimal Caliber { get; set; } | ||||||
|         [Required] public int ApprovalNumber { get; set; } |         [Required] public int ApprovalNumber { get; set; } | ||||||
|         [Required] public decimal Weight { get; set; } |         [Required] public decimal Weight { get; set; } | ||||||
|         [Required] public decimal Nec { get; set; } |         [Required] public decimal Nec { get; set; } | ||||||
|         [Required] public decimal SellingPrice { get; set; } |  | ||||||
|         [Required] public string? Image { get; set; } |         [Required] public string? Image { get; set; } | ||||||
|         [Required, MaxLength(200)] public string? Link { get; set; } |         [Required, MaxLength(200)] public string? Link { get; set; } | ||||||
|         [Required] public int MinimalQuantity { get; set; } |         [Required] public int MinimalQuantity { get; set; } | ||||||
|   | |||||||
| @@ -2,18 +2,27 @@ using API; | |||||||
| using FastEndpoints; | using FastEndpoints; | ||||||
| using FastEndpoints.Swagger; | using FastEndpoints.Swagger; | ||||||
| using PyroFetes; | using PyroFetes; | ||||||
|  | using FastEndpoints.Security; | ||||||
|  |  | ||||||
|  |  | ||||||
| WebApplicationBuilder builder = WebApplication.CreateBuilder(args); | WebApplicationBuilder builder = WebApplication.CreateBuilder(args); | ||||||
|  |  | ||||||
| // On ajoute ici FastEndpoints, un framework REPR et Swagger aux services disponibles dans le projet | // On ajoute ici FastEndpoints, un framework REPR et Swagger aux services disponibles dans le projet | ||||||
| builder.Services.AddFastEndpoints().SwaggerDocument(); | builder.Services | ||||||
|  |     .AddAuthenticationJwtBearer(s => s.SigningKey = "ThisIsASuperSecretJwtKeyThatIsAtLeast32CharsLong") | ||||||
|  |     .AddAuthorization() | ||||||
|  |     .AddFastEndpoints() | ||||||
|  |     .SwaggerDocument(); | ||||||
|  |  | ||||||
| // On ajoute ici la configuration de la base de données | // On ajoute ici la configuration de la base de données | ||||||
| builder.Services.AddDbContext<PyroFetesDbContext>(); | builder.Services.AddDbContext<PyroFetesDbContext>(); | ||||||
|  |  | ||||||
| // On construit l'application en lui donnant vie | // On construit l'application en lui donnant vie | ||||||
| WebApplication app = builder.Build(); | WebApplication app = builder.Build(); | ||||||
| app.UseFastEndpoints().UseSwaggerGen(); | app.UseAuthentication() | ||||||
|  |     .UseAuthorization() | ||||||
|  |     .UseFastEndpoints() | ||||||
|  |     .UseSwaggerGen(); | ||||||
|  |  | ||||||
| app.UseHttpsRedirection(); | app.UseHttpsRedirection(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,9 @@ | |||||||
|     </PropertyGroup> |     </PropertyGroup> | ||||||
|  |  | ||||||
|     <ItemGroup> |     <ItemGroup> | ||||||
|  |         <PackageReference Include="BCrypt.Net-Next" Version="4.0.3" /> | ||||||
|         <PackageReference Include="FastEndpoints" Version="7.0.1" /> |         <PackageReference Include="FastEndpoints" Version="7.0.1" /> | ||||||
|  |         <PackageReference Include="FastEndpoints.Security" Version="7.0.1" /> | ||||||
|         <PackageReference Include="FastEndpoints.Swagger" Version="7.0.1" /> |         <PackageReference Include="FastEndpoints.Swagger" Version="7.0.1" /> | ||||||
|         <PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.19" /> |         <PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.19" /> | ||||||
|         <PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.20" /> |         <PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.20" /> | ||||||
| @@ -16,6 +18,7 @@ | |||||||
|           <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> |           <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> | ||||||
|         </PackageReference> |         </PackageReference> | ||||||
|         <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="8.0.20" /> |         <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="8.0.20" /> | ||||||
|  |         <PackageReference Include="PasswordGenerator" Version="2.1.0" /> | ||||||
|         <PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2" /> |         <PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2" /> | ||||||
|     </ItemGroup> |     </ItemGroup> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,6 +49,7 @@ public class PyroFetesDbContext : DbContext | |||||||
|     public DbSet<User> Users { get; set; } |     public DbSet<User> Users { get; set; } | ||||||
|     public DbSet<Warehouse> Warehouses { get; set; } |     public DbSet<Warehouse> Warehouses { get; set; } | ||||||
|     public DbSet<WarehouseProduct> WarehouseProducts { get; set; } |     public DbSet<WarehouseProduct> WarehouseProducts { get; set; } | ||||||
|  |     public DbSet<Login> Logins { get; set; } | ||||||
|  |  | ||||||
|     // Database configuration |     // Database configuration | ||||||
|     protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) |     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