Compare commits
	
		
			7 Commits
		
	
	
		
			6d044e5de7
			...
			developmen
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 8f64fd51c0 | ||
| a858e5e5de | |||
| c1df5e354b | |||
|   | 27d1bb680b | ||
| 4fa4693bb9 | |||
| 34ada90a28 | |||
| b529d905b1 | 
							
								
								
									
										12
									
								
								.dockerignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.dockerignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | **/bin | ||||||
|  | **/obj | ||||||
|  | **/out | ||||||
|  | **/.vs | ||||||
|  | **/.idea | ||||||
|  | **/.git | ||||||
|  | **/.gitignore | ||||||
|  | **/node_modules | ||||||
|  | *.user | ||||||
|  | *.swp | ||||||
|  | *.swo | ||||||
|  | .DS_Store | ||||||
| @@ -19,10 +19,10 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Base | |||||||
|         public string? BaseDescription { get; set; } |         public string? BaseDescription { get; set; } | ||||||
|         public string? Representation { get; set; } |         public string? Representation { get; set; } | ||||||
|         public string? MaintenanceNotes { get; set; } |         public string? MaintenanceNotes { get; set; } | ||||||
|  |  | ||||||
|         public Dimensions Dimensions { get; set; } = new(); |         public Dimensions Dimensions { get; set; } = new(); | ||||||
|  |  | ||||||
|         public List<string>? VariantIds { get; set; } |         public List<string>? VariantIds { get; set; } | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|  |  | ||||||
|         public bool Validate() |         public bool Validate() | ||||||
|         { |         { | ||||||
|             return !string.IsNullOrWhiteSpace(ModelName) && |             return !string.IsNullOrWhiteSpace(ModelName) && | ||||||
|   | |||||||
| @@ -21,10 +21,10 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Base | |||||||
|         public string? BaseDescription { get; set; } |         public string? BaseDescription { get; set; } | ||||||
|         public string? Representation { get; set; } |         public string? Representation { get; set; } | ||||||
|         public string? MaintenanceNotes { get; set; } |         public string? MaintenanceNotes { get; set; } | ||||||
|  |  | ||||||
|         public Dimensions Dimensions { get; set; } = new(); |         public Dimensions Dimensions { get; set; } = new(); | ||||||
|  |  | ||||||
|         public List<string>? VariantIds { get; set; } |         public List<string>? VariantIds { get; set; } | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|  |  | ||||||
|         public bool Validate() |         public bool Validate() | ||||||
|         { |         { | ||||||
|             return !string.IsNullOrWhiteSpace(_Id) |             return !string.IsNullOrWhiteSpace(_Id) | ||||||
|   | |||||||
| @@ -13,15 +13,13 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Variant | |||||||
|         public string Name { get; set; } = null!; |         public string Name { get; set; } = null!; | ||||||
|         public string Color { get; set; } = null!; |         public string Color { get; set; } = null!; | ||||||
|         public string? Line { get; set; } |         public string? Line { get; set; } | ||||||
|  |  | ||||||
|         public decimal Price { get; set; } |         public decimal Price { get; set; } | ||||||
|         public string Currency { get; set; } = "USD"; |         public string Currency { get; set; } = "USD"; | ||||||
|         public int Stock { get; set; } |         public int Stock { get; set; } | ||||||
|  |  | ||||||
|         public string CategoryId { get; set; } = string.Empty; |         public string CategoryId { get; set; } = string.Empty; | ||||||
|         public string ProviderId { get; set; } = string.Empty; |         public string ProviderId { get; set; } = string.Empty; | ||||||
|  |  | ||||||
|         public Dictionary<string, string> Attributes { get; set; } = []; |         public Dictionary<string, string> Attributes { get; set; } = []; | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|  |  | ||||||
|         public bool Validate() |         public bool Validate() | ||||||
|         { |         { | ||||||
|   | |||||||
| @@ -23,11 +23,10 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Variant | |||||||
|         public int Stock { get; set; } |         public int Stock { get; set; } | ||||||
|         public decimal Price { get; set; } |         public decimal Price { get; set; } | ||||||
|         public string Currency { get; set; } = "USD"; |         public string Currency { get; set; } = "USD"; | ||||||
|  |  | ||||||
|         public string CategoryId { get; set; } = string.Empty!; |         public string CategoryId { get; set; } = string.Empty!; | ||||||
|         public string ProviderId { get; set; } = string.Empty!; |         public string ProviderId { get; set; } = string.Empty!; | ||||||
|  |  | ||||||
|         public Dictionary<string, string> Attributes { get; set; } = []; |         public Dictionary<string, string> Attributes { get; set; } = []; | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|  |  | ||||||
|         public bool Validate() |         public bool Validate() | ||||||
|         { |         { | ||||||
|   | |||||||
| @@ -94,7 +94,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | |||||||
|                         Depth = command.Dimensions.Depth, |                         Depth = command.Dimensions.Depth, | ||||||
|                         Height = command.Dimensions.Height, |                         Height = command.Dimensions.Height, | ||||||
|                         Width = command.Dimensions.Width |                         Width = command.Dimensions.Width | ||||||
|                     } |                     }, | ||||||
|  |                     Icon = command.Icon | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
|                 var result = await _inventoryDALService.CreateFurnitureBaseAsync(request, cancellationToken); |                 var result = await _inventoryDALService.CreateFurnitureBaseAsync(request, cancellationToken); | ||||||
| @@ -133,7 +134,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | |||||||
|                         Depth = command.Dimensions.Depth, |                         Depth = command.Dimensions.Depth, | ||||||
|                         Height = command.Dimensions.Height, |                         Height = command.Dimensions.Height, | ||||||
|                         Width = command.Dimensions.Width |                         Width = command.Dimensions.Width | ||||||
|                     } |                     }, | ||||||
|  |                     Icon = command.Icon | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
|                 var result = await _inventoryDALService.UpdateFurnitureBaseAsync(command.Id, request, cancellationToken); |                 var result = await _inventoryDALService.UpdateFurnitureBaseAsync(command.Id, request, cancellationToken); | ||||||
| @@ -226,7 +228,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | |||||||
|                     ModelId = command.ModelId, |                     ModelId = command.ModelId, | ||||||
|                     Name = command.Name, |                     Name = command.Name, | ||||||
|                     Price = command.Price, |                     Price = command.Price, | ||||||
|                     ProviderId  = command.ProviderId |                     ProviderId  = command.ProviderId, | ||||||
|  |                     Icon = command.Icon | ||||||
|                 }; |                 }; | ||||||
|                 var result = await _inventoryDALService.CreateFurnitureVariantAsync(request, cancellationToken); |                 var result = await _inventoryDALService.CreateFurnitureVariantAsync(request, cancellationToken); | ||||||
|                 _variantPort.Success(result); |                 _variantPort.Success(result); | ||||||
| @@ -260,7 +263,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | |||||||
|                     ModelId = command.ModelId, |                     ModelId = command.ModelId, | ||||||
|                     Name = command.Name, |                     Name = command.Name, | ||||||
|                     Price = command.Price, |                     Price = command.Price, | ||||||
|                     ProviderId = command.ProviderId |                     ProviderId = command.ProviderId, | ||||||
|  |                     Icon = command.Icon | ||||||
|                 }; |                 }; | ||||||
|                 var result = await _inventoryDALService.UpdateFurnitureVariantAsync(command.Id, request, cancellationToken); |                 var result = await _inventoryDALService.UpdateFurnitureVariantAsync(command.Id, request, cancellationToken); | ||||||
|                 _variantPort.Success(result); |                 _variantPort.Success(result); | ||||||
|   | |||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | namespace Core.Inventory.Application.UseCases.Product.Adapter | ||||||
|  | { | ||||||
|  |     public class DeleteProductResponseAdapter | ||||||
|  |     { | ||||||
|  |         public bool Success { get; init; } | ||||||
|  |     } | ||||||
|  | }  | ||||||
| @@ -15,5 +15,9 @@ namespace Core.Inventory.Application.UseCases.Product.Adapter | |||||||
|         { |         { | ||||||
|             ViewModel = new OkObjectResult(output); |             ViewModel = new OkObjectResult(output); | ||||||
|         } |         } | ||||||
|  |         public void Success(DeleteProductResponseAdapter output) | ||||||
|  |         { | ||||||
|  |             ViewModel = new OkObjectResult(output); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| }  | }  | ||||||
| @@ -7,7 +7,7 @@ namespace Core.Inventory.Application.UseCases.Product.Input | |||||||
|         public string TenantId { get; set; } = null!; |         public string TenantId { get; set; } = null!; | ||||||
|         public string ProductName { get; set; } = null!; |         public string ProductName { get; set; } = null!; | ||||||
|         public string Description { get; set; } = null!; |         public string Description { get; set; } = null!; | ||||||
|         public string Status { get; set; } = null!; |         public string ProductStatus { get; set; } = null!; | ||||||
|         public List<string> TagIds { get; set; } = new List<string>(); |         public List<string> TagIds { get; set; } = new List<string>(); | ||||||
|  |  | ||||||
|         public bool Validate() |         public bool Validate() | ||||||
|   | |||||||
| @@ -0,0 +1,14 @@ | |||||||
|  | using Lib.Architecture.BuildingBlocks; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.Product.Input | ||||||
|  | { | ||||||
|  |     public class DeleteProductRequest : Notificator, ICommand | ||||||
|  |     { | ||||||
|  |         public string Id { get; set; } = null!; | ||||||
|  |  | ||||||
|  |         public bool Validate() | ||||||
|  |         { | ||||||
|  |             return Id != null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }  | ||||||
| @@ -9,7 +9,7 @@ namespace Core.Inventory.Application.UseCases.Product.Input | |||||||
|         public string TenantId { get; set; } = null!; |         public string TenantId { get; set; } = null!; | ||||||
|         public string ProductName { get; set; } = null!; |         public string ProductName { get; set; } = null!; | ||||||
|         public string Description { get; set; } = null!; |         public string Description { get; set; } = null!; | ||||||
|         public string Status { get; set; } = null!; |         public string ProductStatus { get; set; } = null!; | ||||||
|         public List<string> TagIds { get; set; } = new List<string>(); |         public List<string> TagIds { get; set; } = new List<string>(); | ||||||
|  |  | ||||||
|         public bool Validate() |         public bool Validate() | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| using Core.Adapters.Lib.Inventory; | using Core.Adapters.Lib.Inventory; | ||||||
|  | using Core.Inventory.Application.UseCases.Product.Adapter; | ||||||
| using Lib.Architecture.BuildingBlocks; | using Lib.Architecture.BuildingBlocks; | ||||||
|  |  | ||||||
| namespace Core.Inventory.Application.UseCases.Product.Ports | namespace Core.Inventory.Application.UseCases.Product.Ports | ||||||
| @@ -6,6 +7,7 @@ namespace Core.Inventory.Application.UseCases.Product.Ports | |||||||
|     public interface IProductPort : IBasePort, |     public interface IProductPort : IBasePort, | ||||||
|         ICommandSuccessPort<ProductAdapter>, |         ICommandSuccessPort<ProductAdapter>, | ||||||
|         ICommandSuccessPort<List<ProductAdapter>>, |         ICommandSuccessPort<List<ProductAdapter>>, | ||||||
|  |         ICommandSuccessPort<DeleteProductResponseAdapter>, | ||||||
|         INoContentPort, IBusinessErrorPort, ITimeoutPort, IValidationErrorPort, |         INoContentPort, IBusinessErrorPort, ITimeoutPort, IValidationErrorPort, | ||||||
|         INotFoundPort, IForbiddenPort, IUnauthorizedPort, IInternalServerErrorPort, |         INotFoundPort, IForbiddenPort, IUnauthorizedPort, IInternalServerErrorPort, | ||||||
|         IBadRequestPort |         IBadRequestPort | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| using Core.Adapters.Lib.Inventory; | using Core.Adapters.Lib.Inventory; | ||||||
|  | using Core.Inventory.Application.UseCases.Product.Adapter; | ||||||
| using Core.Inventory.Application.UseCases.Product.Input; | using Core.Inventory.Application.UseCases.Product.Input; | ||||||
| using Core.Inventory.Application.UseCases.Product.Ports; | using Core.Inventory.Application.UseCases.Product.Ports; | ||||||
| using Core.Inventory.External.Clients; | using Core.Inventory.External.Clients; | ||||||
| @@ -15,13 +16,15 @@ namespace Core.Inventory.Application.UseCases.Product | |||||||
|         IComponentHandler<GetAllProductsByListRequest>, |         IComponentHandler<GetAllProductsByListRequest>, | ||||||
|         IComponentHandler<UpdateProductRequest>, |         IComponentHandler<UpdateProductRequest>, | ||||||
|         IComponentHandler<GetProductRequest>, |         IComponentHandler<GetProductRequest>, | ||||||
|         IComponentHandler<CreateProductRequest> |         IComponentHandler<CreateProductRequest>, | ||||||
|  |         IComponentHandler<DeleteProductRequest> | ||||||
|     { |     { | ||||||
|         private readonly IProductPort _port; |         private readonly IProductPort _port; | ||||||
|         private readonly IValidator<ChangeProductStatusRequest> _changeProductStatusValidator; |         private readonly IValidator<ChangeProductStatusRequest> _changeProductStatusValidator; | ||||||
|         private readonly IValidator<CreateProductRequest> _registerProductValidator; |         private readonly IValidator<CreateProductRequest> _registerProductValidator; | ||||||
|         private readonly IValidator<UpdateProductRequest> _updateProductValidator; |         private readonly IValidator<UpdateProductRequest> _updateProductValidator; | ||||||
|         private readonly IValidator<GetAllProductsByListRequest> _productsByListValidator; |         private readonly IValidator<GetAllProductsByListRequest> _productsByListValidator; | ||||||
|  |         private readonly IValidator<DeleteProductRequest> _deleteProductValidator; | ||||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; |         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||||
|  |  | ||||||
|         public ProductHandler( |         public ProductHandler( | ||||||
| @@ -30,6 +33,7 @@ namespace Core.Inventory.Application.UseCases.Product | |||||||
|             IValidator<CreateProductRequest> registerProductValidator, |             IValidator<CreateProductRequest> registerProductValidator, | ||||||
|             IValidator<UpdateProductRequest> updateProductValidator, |             IValidator<UpdateProductRequest> updateProductValidator, | ||||||
|             IValidator<GetAllProductsByListRequest> productsByListValidator, |             IValidator<GetAllProductsByListRequest> productsByListValidator, | ||||||
|  |             IValidator<DeleteProductRequest> deleteProductValidator, | ||||||
|             IInventoryServiceClient inventoryDALService) |             IInventoryServiceClient inventoryDALService) | ||||||
|         { |         { | ||||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); |             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||||
| @@ -38,6 +42,7 @@ namespace Core.Inventory.Application.UseCases.Product | |||||||
|             _updateProductValidator = updateProductValidator ?? throw new ArgumentNullException(nameof(updateProductValidator)); |             _updateProductValidator = updateProductValidator ?? throw new ArgumentNullException(nameof(updateProductValidator)); | ||||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); |             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||||
|             _productsByListValidator = productsByListValidator ?? throw new ArgumentNullException(nameof(productsByListValidator)); |             _productsByListValidator = productsByListValidator ?? throw new ArgumentNullException(nameof(productsByListValidator)); | ||||||
|  |             _deleteProductValidator = deleteProductValidator ?? throw new ArgumentNullException(nameof(deleteProductValidator)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public async ValueTask ExecuteAsync(GetProductRequest command, CancellationToken cancellationToken = default) |         public async ValueTask ExecuteAsync(GetProductRequest command, CancellationToken cancellationToken = default) | ||||||
| @@ -153,7 +158,7 @@ namespace Core.Inventory.Application.UseCases.Product | |||||||
|                     TenantId = command.TenantId, |                     TenantId = command.TenantId, | ||||||
|                     ProductName = command.ProductName, |                     ProductName = command.ProductName, | ||||||
|                     Description = command.Description, |                     Description = command.Description, | ||||||
|                     Status = command.Status, |                     ProductStatus = command.ProductStatus, | ||||||
|                     TagIds = command.TagIds |                     TagIds = command.TagIds | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
| @@ -191,7 +196,7 @@ namespace Core.Inventory.Application.UseCases.Product | |||||||
|                     TenantId = command.TenantId, |                     TenantId = command.TenantId, | ||||||
|                     ProductName = command.ProductName, |                     ProductName = command.ProductName, | ||||||
|                     Description = command.Description, |                     Description = command.Description, | ||||||
|                     Status = Enum.Parse<ProductStatus>(command.Status), |                     ProductStatus = Enum.Parse<ProductStatus>(command.ProductStatus), | ||||||
|                     TagIds = command.TagIds.Select(id => MongoDB.Bson.ObjectId.Parse(id)).ToList() |                     TagIds = command.TagIds.Select(id => MongoDB.Bson.ObjectId.Parse(id)).ToList() | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
| @@ -210,5 +215,33 @@ namespace Core.Inventory.Application.UseCases.Product | |||||||
|                 ApiResponseHelper.EvaluatePort(ex, _port); |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public async ValueTask ExecuteAsync(DeleteProductRequest command, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 ArgumentNullException.ThrowIfNull(command); | ||||||
|  |  | ||||||
|  |                 if (!command.IsValid(_deleteProductValidator)) | ||||||
|  |                 { | ||||||
|  |                     _port.ValidationErrors(command.Notifications); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 var result = await _inventoryServiceClient.DeleteProductAsync(command.Id, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |                 if (!result) | ||||||
|  |                 { | ||||||
|  |                     _port.NoContentSuccess(); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 _port.Success(new DeleteProductResponseAdapter() { Success = true }); | ||||||
|  |             } | ||||||
|  |             catch (Exception ex) | ||||||
|  |             { | ||||||
|  |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -0,0 +1,13 @@ | |||||||
|  | using Core.Inventory.Application.UseCases.Product.Input; | ||||||
|  | using FluentValidation; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.Product.Validator | ||||||
|  | { | ||||||
|  |     public class DeleteProductValidator : AbstractValidator<DeleteProductRequest> | ||||||
|  |     { | ||||||
|  |         public DeleteProductValidator() | ||||||
|  |         { | ||||||
|  |             RuleFor(i => i.Id).NotEmpty().NotNull().OverridePropertyName(x => x.Id).WithName("Product Id").WithMessage("Product Id is Obligatory."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }  | ||||||
| @@ -0,0 +1,14 @@ | |||||||
|  | using Lib.Architecture.BuildingBlocks; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.Tag.Input | ||||||
|  | { | ||||||
|  |     public class DeleteTagRequest : Notificator, ICommand | ||||||
|  |     { | ||||||
|  |         public string Id { get; set; } = null!; | ||||||
|  |  | ||||||
|  |         public bool Validate() | ||||||
|  |         { | ||||||
|  |             return Id != null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -17,7 +17,8 @@ namespace Core.Inventory.Application.UseCases.Tag | |||||||
|         IComponentHandler<GetTagRequest>, |         IComponentHandler<GetTagRequest>, | ||||||
|         IComponentHandler<CreateTagRequest>, |         IComponentHandler<CreateTagRequest>, | ||||||
|         IComponentHandler<AddParentTagToTagRequest>, |         IComponentHandler<AddParentTagToTagRequest>, | ||||||
|         IComponentHandler<RemoveParentTagFromTagRequest> |         IComponentHandler<RemoveParentTagFromTagRequest>, | ||||||
|  |         IComponentHandler<DeleteTagRequest> | ||||||
|     { |     { | ||||||
|         private readonly ITagPort _port; |         private readonly ITagPort _port; | ||||||
|         private readonly IValidator<ChangeTagStatusRequest> _changeTagStatusValidator; |         private readonly IValidator<ChangeTagStatusRequest> _changeTagStatusValidator; | ||||||
| @@ -25,6 +26,7 @@ namespace Core.Inventory.Application.UseCases.Tag | |||||||
|         private readonly IValidator<UpdateTagRequest> _updateTagValidator; |         private readonly IValidator<UpdateTagRequest> _updateTagValidator; | ||||||
|         private readonly IValidator<GetAllTagsByListRequest> _TagsByListValidator; |         private readonly IValidator<GetAllTagsByListRequest> _TagsByListValidator; | ||||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; |         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||||
|  |         private readonly IValidator<DeleteTagRequest> _deleteTagValidator; | ||||||
|  |  | ||||||
|         public TagHandler( |         public TagHandler( | ||||||
|             ITagPort port, |             ITagPort port, | ||||||
| @@ -32,6 +34,7 @@ namespace Core.Inventory.Application.UseCases.Tag | |||||||
|             IValidator<CreateTagRequest> registerTagValidator, |             IValidator<CreateTagRequest> registerTagValidator, | ||||||
|             IValidator<UpdateTagRequest> updateTagValidator, |             IValidator<UpdateTagRequest> updateTagValidator, | ||||||
|             IValidator<GetAllTagsByListRequest> TagsByListValidator, |             IValidator<GetAllTagsByListRequest> TagsByListValidator, | ||||||
|  |             IValidator<DeleteTagRequest> deleteTagValidator, | ||||||
|             IInventoryServiceClient inventoryDALService) |             IInventoryServiceClient inventoryDALService) | ||||||
|         { |         { | ||||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); |             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||||
| @@ -40,6 +43,7 @@ namespace Core.Inventory.Application.UseCases.Tag | |||||||
|             _updateTagValidator = updateTagValidator ?? throw new ArgumentNullException(nameof(updateTagValidator)); |             _updateTagValidator = updateTagValidator ?? throw new ArgumentNullException(nameof(updateTagValidator)); | ||||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); |             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||||
|             _TagsByListValidator = TagsByListValidator ?? throw new ArgumentNullException(nameof(TagsByListValidator)); |             _TagsByListValidator = TagsByListValidator ?? throw new ArgumentNullException(nameof(TagsByListValidator)); | ||||||
|  |             _deleteTagValidator = deleteTagValidator ?? throw new ArgumentNullException(nameof(deleteTagValidator)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public async ValueTask ExecuteAsync(GetTagRequest command, CancellationToken cancellationToken = default) |         public async ValueTask ExecuteAsync(GetTagRequest command, CancellationToken cancellationToken = default) | ||||||
| @@ -262,5 +266,33 @@ namespace Core.Inventory.Application.UseCases.Tag | |||||||
|                 ApiResponseHelper.EvaluatePort(ex, _port); |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public async ValueTask ExecuteAsync(DeleteTagRequest command, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 ArgumentNullException.ThrowIfNull(command); | ||||||
|  |  | ||||||
|  |                 if (!command.IsValid(_deleteTagValidator)) | ||||||
|  |                 { | ||||||
|  |                     _port.ValidationErrors(command.Notifications); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 var result = await _inventoryServiceClient.DeleteTagAsync(command.Id, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |                 if (result == null) | ||||||
|  |                 { | ||||||
|  |                     _port.NoContentSuccess(); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 _port.Success(result); | ||||||
|  |             } | ||||||
|  |             catch (Exception ex) | ||||||
|  |             { | ||||||
|  |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,13 @@ | |||||||
|  | using Core.Inventory.Application.UseCases.Tag.Input; | ||||||
|  | using FluentValidation; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.Tag.Validator | ||||||
|  | { | ||||||
|  |     public class DeleteTagValidator : AbstractValidator<DeleteTagRequest> | ||||||
|  |     { | ||||||
|  |         public DeleteTagValidator() | ||||||
|  |         { | ||||||
|  |             RuleFor(i => i.Id).NotEmpty().NotNull().OverridePropertyName(x => x.Id).WithName("Tag Id").WithMessage("Tag Id is Obligatory."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,14 @@ | |||||||
|  | using Lib.Architecture.BuildingBlocks; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.TagOverride.Input | ||||||
|  | { | ||||||
|  |     public class DeleteTagOverrideRequest : Notificator, ICommand | ||||||
|  |     { | ||||||
|  |         public string Id { get; set; } = null!; | ||||||
|  |  | ||||||
|  |         public bool Validate() | ||||||
|  |         { | ||||||
|  |             return Id != null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -15,7 +15,8 @@ namespace Core.Inventory.Application.UseCases.TagOverride | |||||||
|         IComponentHandler<GetAllTagOverridesByListRequest>, |         IComponentHandler<GetAllTagOverridesByListRequest>, | ||||||
|         IComponentHandler<UpdateTagOverrideRequest>, |         IComponentHandler<UpdateTagOverrideRequest>, | ||||||
|         IComponentHandler<GetTagOverrideRequest>, |         IComponentHandler<GetTagOverrideRequest>, | ||||||
|         IComponentHandler<CreateTagOverrideRequest> |         IComponentHandler<CreateTagOverrideRequest>, | ||||||
|  |         IComponentHandler<DeleteTagOverrideRequest> | ||||||
|     { |     { | ||||||
|         private readonly ITagOverridePort _port; |         private readonly ITagOverridePort _port; | ||||||
|         private readonly IValidator<ChangeTagOverrideStatusRequest> _changeTagOverrideStatusValidator; |         private readonly IValidator<ChangeTagOverrideStatusRequest> _changeTagOverrideStatusValidator; | ||||||
| @@ -23,6 +24,7 @@ namespace Core.Inventory.Application.UseCases.TagOverride | |||||||
|         private readonly IValidator<UpdateTagOverrideRequest> _updateTagOverrideValidator; |         private readonly IValidator<UpdateTagOverrideRequest> _updateTagOverrideValidator; | ||||||
|         private readonly IValidator<GetAllTagOverridesByListRequest> _TagOverridesByListValidator; |         private readonly IValidator<GetAllTagOverridesByListRequest> _TagOverridesByListValidator; | ||||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; |         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||||
|  |         private readonly IValidator<DeleteTagOverrideRequest> _deleteTagOverrideValidator; | ||||||
|  |  | ||||||
|         public TagOverrideHandler( |         public TagOverrideHandler( | ||||||
|             ITagOverridePort port, |             ITagOverridePort port, | ||||||
| @@ -30,6 +32,7 @@ namespace Core.Inventory.Application.UseCases.TagOverride | |||||||
|             IValidator<CreateTagOverrideRequest> registerTagOverrideValidator, |             IValidator<CreateTagOverrideRequest> registerTagOverrideValidator, | ||||||
|             IValidator<UpdateTagOverrideRequest> updateTagOverrideValidator, |             IValidator<UpdateTagOverrideRequest> updateTagOverrideValidator, | ||||||
|             IValidator<GetAllTagOverridesByListRequest> TagOverridesByListValidator, |             IValidator<GetAllTagOverridesByListRequest> TagOverridesByListValidator, | ||||||
|  |             IValidator<DeleteTagOverrideRequest> deleteTagOverrideValidator, | ||||||
|             IInventoryServiceClient inventoryDALService) |             IInventoryServiceClient inventoryDALService) | ||||||
|         { |         { | ||||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); |             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||||
| @@ -38,6 +41,7 @@ namespace Core.Inventory.Application.UseCases.TagOverride | |||||||
|             _updateTagOverrideValidator = updateTagOverrideValidator ?? throw new ArgumentNullException(nameof(updateTagOverrideValidator)); |             _updateTagOverrideValidator = updateTagOverrideValidator ?? throw new ArgumentNullException(nameof(updateTagOverrideValidator)); | ||||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); |             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||||
|             _TagOverridesByListValidator = TagOverridesByListValidator ?? throw new ArgumentNullException(nameof(TagOverridesByListValidator)); |             _TagOverridesByListValidator = TagOverridesByListValidator ?? throw new ArgumentNullException(nameof(TagOverridesByListValidator)); | ||||||
|  |             _deleteTagOverrideValidator = deleteTagOverrideValidator ?? throw new ArgumentNullException(nameof(deleteTagOverrideValidator)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public async ValueTask ExecuteAsync(GetTagOverrideRequest command, CancellationToken cancellationToken = default) |         public async ValueTask ExecuteAsync(GetTagOverrideRequest command, CancellationToken cancellationToken = default) | ||||||
| @@ -208,5 +212,33 @@ namespace Core.Inventory.Application.UseCases.TagOverride | |||||||
|                 ApiResponseHelper.EvaluatePort(ex, _port); |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public async ValueTask ExecuteAsync(DeleteTagOverrideRequest command, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 ArgumentNullException.ThrowIfNull(command); | ||||||
|  |  | ||||||
|  |                 if (!command.IsValid(_deleteTagOverrideValidator)) | ||||||
|  |                 { | ||||||
|  |                     _port.ValidationErrors(command.Notifications); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 var result = await _inventoryServiceClient.DeleteTagOverrideAsync(command.Id, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |                 if (result == null) | ||||||
|  |                 { | ||||||
|  |                     _port.NoContentSuccess(); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 _port.Success(result); | ||||||
|  |             } | ||||||
|  |             catch (Exception ex) | ||||||
|  |             { | ||||||
|  |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,13 @@ | |||||||
|  | using Core.Inventory.Application.UseCases.TagOverride.Input; | ||||||
|  | using FluentValidation; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.TagOverride.Validator | ||||||
|  | { | ||||||
|  |     public class DeleteTagOverrideValidator : AbstractValidator<DeleteTagOverrideRequest> | ||||||
|  |     { | ||||||
|  |         public DeleteTagOverrideValidator() | ||||||
|  |         { | ||||||
|  |             RuleFor(i => i.Id).NotEmpty().NotNull().OverridePropertyName(x => x.Id).WithName("TagOverride Id").WithMessage("TagOverride Id is Obligatory."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,14 @@ | |||||||
|  | using Lib.Architecture.BuildingBlocks; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.TagType.Input | ||||||
|  | { | ||||||
|  |     public class DeleteTagTypeRequest : Notificator, ICommand | ||||||
|  |     { | ||||||
|  |         public string Id { get; set; } = null!; | ||||||
|  |  | ||||||
|  |         public bool Validate() | ||||||
|  |         { | ||||||
|  |             return Id != null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -15,13 +15,15 @@ namespace Core.Inventory.Application.UseCases.TagType | |||||||
|         IComponentHandler<GetAllTagTypesByListRequest>, |         IComponentHandler<GetAllTagTypesByListRequest>, | ||||||
|         IComponentHandler<UpdateTagTypeRequest>, |         IComponentHandler<UpdateTagTypeRequest>, | ||||||
|         IComponentHandler<GetTagTypeRequest>, |         IComponentHandler<GetTagTypeRequest>, | ||||||
|         IComponentHandler<CreateTagTypeRequest> |         IComponentHandler<CreateTagTypeRequest>, | ||||||
|  |         IComponentHandler<DeleteTagTypeRequest> | ||||||
|     { |     { | ||||||
|         private readonly ITagTypePort _port; |         private readonly ITagTypePort _port; | ||||||
|         private readonly IValidator<ChangeTagTypeStatusRequest> _changeTagTypeStatusValidator; |         private readonly IValidator<ChangeTagTypeStatusRequest> _changeTagTypeStatusValidator; | ||||||
|         private readonly IValidator<CreateTagTypeRequest> _registerTagTypeValidator; |         private readonly IValidator<CreateTagTypeRequest> _registerTagTypeValidator; | ||||||
|         private readonly IValidator<UpdateTagTypeRequest> _updateTagTypeValidator; |         private readonly IValidator<UpdateTagTypeRequest> _updateTagTypeValidator; | ||||||
|         private readonly IValidator<GetAllTagTypesByListRequest> _TagTypesByListValidator; |         private readonly IValidator<GetAllTagTypesByListRequest> _TagTypesByListValidator; | ||||||
|  |         private readonly IValidator<DeleteTagTypeRequest> _deleteTagTypeValidator; | ||||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; |         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||||
|  |  | ||||||
|         public TagTypeHandler( |         public TagTypeHandler( | ||||||
| @@ -30,6 +32,7 @@ namespace Core.Inventory.Application.UseCases.TagType | |||||||
|             IValidator<CreateTagTypeRequest> registerTagTypeValidator, |             IValidator<CreateTagTypeRequest> registerTagTypeValidator, | ||||||
|             IValidator<UpdateTagTypeRequest> updateTagTypeValidator, |             IValidator<UpdateTagTypeRequest> updateTagTypeValidator, | ||||||
|             IValidator<GetAllTagTypesByListRequest> TagTypesByListValidator, |             IValidator<GetAllTagTypesByListRequest> TagTypesByListValidator, | ||||||
|  |             IValidator<DeleteTagTypeRequest> deleteTagTypeValidator, | ||||||
|             IInventoryServiceClient inventoryDALService) |             IInventoryServiceClient inventoryDALService) | ||||||
|         { |         { | ||||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); |             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||||
| @@ -38,6 +41,7 @@ namespace Core.Inventory.Application.UseCases.TagType | |||||||
|             _updateTagTypeValidator = updateTagTypeValidator ?? throw new ArgumentNullException(nameof(updateTagTypeValidator)); |             _updateTagTypeValidator = updateTagTypeValidator ?? throw new ArgumentNullException(nameof(updateTagTypeValidator)); | ||||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); |             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||||
|             _TagTypesByListValidator = TagTypesByListValidator ?? throw new ArgumentNullException(nameof(TagTypesByListValidator)); |             _TagTypesByListValidator = TagTypesByListValidator ?? throw new ArgumentNullException(nameof(TagTypesByListValidator)); | ||||||
|  |             _deleteTagTypeValidator = deleteTagTypeValidator ?? throw new ArgumentNullException(nameof(deleteTagTypeValidator)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public async ValueTask ExecuteAsync(GetTagTypeRequest command, CancellationToken cancellationToken = default) |         public async ValueTask ExecuteAsync(GetTagTypeRequest command, CancellationToken cancellationToken = default) | ||||||
| @@ -210,5 +214,33 @@ namespace Core.Inventory.Application.UseCases.TagType | |||||||
|                 ApiResponseHelper.EvaluatePort(ex, _port); |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public async ValueTask ExecuteAsync(DeleteTagTypeRequest command, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 ArgumentNullException.ThrowIfNull(command); | ||||||
|  |  | ||||||
|  |                 if (!command.IsValid(_deleteTagTypeValidator)) | ||||||
|  |                 { | ||||||
|  |                     _port.ValidationErrors(command.Notifications); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 var result = await _inventoryServiceClient.DeleteTagTypeAsync(command.Id, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |                 if (result == null) | ||||||
|  |                 { | ||||||
|  |                     _port.NoContentSuccess(); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 _port.Success(result); | ||||||
|  |             } | ||||||
|  |             catch (Exception ex) | ||||||
|  |             { | ||||||
|  |                 ApiResponseHelper.EvaluatePort(ex, _port); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,13 @@ | |||||||
|  | using Core.Inventory.Application.UseCases.TagType.Input; | ||||||
|  | using FluentValidation; | ||||||
|  |  | ||||||
|  | namespace Core.Inventory.Application.UseCases.TagType.Validator | ||||||
|  | { | ||||||
|  |     public class DeleteTagTypeValidator : AbstractValidator<DeleteTagTypeRequest> | ||||||
|  |     { | ||||||
|  |         public DeleteTagTypeValidator() | ||||||
|  |         { | ||||||
|  |             RuleFor(i => i.Id).NotEmpty().NotNull().OverridePropertyName(x => x.Id).WithName("TagType Id").WithMessage("TagType Id is Obligatory."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -15,5 +15,6 @@ namespace Core.Inventory.External.Clients.Adapters | |||||||
|  |  | ||||||
|         public Dimensions Dimensions { get; set; } = new(); |         public Dimensions Dimensions { get; set; } = new(); | ||||||
|         public List<string>? VariantIds { get; set; } |         public List<string>? VariantIds { get; set; } | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -17,5 +17,6 @@ | |||||||
|         public string ProviderId { get; set; } = string.Empty!; |         public string ProviderId { get; set; } = string.Empty!; | ||||||
|  |  | ||||||
|         public Dictionary<string, string> Attributes { get; set; } = []; |         public Dictionary<string, string> Attributes { get; set; } = []; | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -73,6 +73,9 @@ namespace Core.Inventory.External.Clients | |||||||
|         [Patch("/api/v1/TagType/{id}/{newStatus}/ChangeStatus")] |         [Patch("/api/v1/TagType/{id}/{newStatus}/ChangeStatus")] | ||||||
|         Task<TagTypeAdapter> ChangeStatusTagTypeAsync([FromRoute] string id, [FromRoute] StatusEnum newStatus, CancellationToken cancellationToken = default); |         Task<TagTypeAdapter> ChangeStatusTagTypeAsync([FromRoute] string id, [FromRoute] StatusEnum newStatus, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|  |         [Delete("/api/v1/TagType/{id}")] | ||||||
|  |         Task<TagTypeAdapter> DeleteTagTypeAsync([FromRoute] string id, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|         #endregion |         #endregion | ||||||
|  |  | ||||||
|         #region Tag |         #region Tag | ||||||
| @@ -101,6 +104,9 @@ namespace Core.Inventory.External.Clients | |||||||
|         [Delete("/api/v1/Tag/{tagId}/ParentTags/{parentTagId}/Remove")] |         [Delete("/api/v1/Tag/{tagId}/ParentTags/{parentTagId}/Remove")] | ||||||
|         Task<TagAdapter> RemoveParentTagAsync([FromRoute] string tagId, [FromRoute] string parentTagId, CancellationToken cancellationToken = default); |         Task<TagAdapter> RemoveParentTagAsync([FromRoute] string tagId, [FromRoute] string parentTagId, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|  |         [Delete("/api/v1/Tag/{id}")] | ||||||
|  |         Task<TagAdapter> DeleteTagAsync([FromRoute] string id, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|         #endregion |         #endregion | ||||||
|  |  | ||||||
|         #region TagOverride |         #region TagOverride | ||||||
| @@ -123,6 +129,9 @@ namespace Core.Inventory.External.Clients | |||||||
|         [Patch("/api/v1/TagOverride/{id}/{newStatus}/ChangeStatus")] |         [Patch("/api/v1/TagOverride/{id}/{newStatus}/ChangeStatus")] | ||||||
|         Task<TagOverrideAdapter> ChangeStatusTagOverrideAsync([FromRoute] string id, [FromRoute] StatusEnum newStatus, CancellationToken cancellationToken = default); |         Task<TagOverrideAdapter> ChangeStatusTagOverrideAsync([FromRoute] string id, [FromRoute] StatusEnum newStatus, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|  |         [Delete("/api/v1/TagOverride/{id}")] | ||||||
|  |         Task<TagOverrideAdapter> DeleteTagOverrideAsync([FromRoute] string id, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|         #endregion |         #endregion | ||||||
|  |  | ||||||
|         #region Product |         #region Product | ||||||
| @@ -151,6 +160,9 @@ namespace Core.Inventory.External.Clients | |||||||
|         [Delete("/api/v1/Product/{productId}/tags/{tagId}")] |         [Delete("/api/v1/Product/{productId}/tags/{tagId}")] | ||||||
|         Task<ProductAdapter> RemoveTagFromProductAsync([FromRoute] string productId, [FromRoute] string tagId, CancellationToken cancellationToken = default); |         Task<ProductAdapter> RemoveTagFromProductAsync([FromRoute] string productId, [FromRoute] string tagId, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|  |         [Delete("/api/v1/Product/{id}")] | ||||||
|  |         Task<bool> DeleteProductAsync([FromRoute] string id, CancellationToken cancellationToken = default); | ||||||
|  |  | ||||||
|         #endregion |         #endregion | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,8 +10,8 @@ namespace Core.Inventory.External.Clients.Requests | |||||||
|         public string? BaseDescription { get; set; } |         public string? BaseDescription { get; set; } | ||||||
|         public string? Representation { get; set; } |         public string? Representation { get; set; } | ||||||
|         public string? MaintenanceNotes { get; set; } |         public string? MaintenanceNotes { get; set; } | ||||||
|  |  | ||||||
|         public Dimensions Dimensions { get; set; } = new(); |         public Dimensions Dimensions { get; set; } = new(); | ||||||
|         public List<string>? VariantIds { get; set; } |         public List<string>? VariantIds { get; set; } | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -15,5 +15,7 @@ | |||||||
|         public string ProviderId { get; set; } = string.Empty!; |         public string ProviderId { get; set; } = string.Empty!; | ||||||
|  |  | ||||||
|         public Dictionary<string, string> Attributes { get; set; } = []; |         public Dictionary<string, string> Attributes { get; set; } = []; | ||||||
|  |  | ||||||
|  |         public string Icon { get; set; } = null!; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ namespace Core.Inventory.External.Clients.Requests | |||||||
|         public string TenantId { get; set; } = null!; |         public string TenantId { get; set; } = null!; | ||||||
|         public string ProductName { get; set; } = null!; |         public string ProductName { get; set; } = null!; | ||||||
|         public string Description { get; set; } = null!; |         public string Description { get; set; } = null!; | ||||||
|         public string Status { get; set; } = null!; |         public string ProductStatus { get; set; } = null!; | ||||||
|         public List<string> TagIds { get; set; } = new List<string>(); |         public List<string> TagIds { get; set; } = new List<string>(); | ||||||
|     } |     } | ||||||
| }  | }  | ||||||
| @@ -7,8 +7,8 @@ | |||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
|  |  | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="Adapters.Lib" Version="1.0.11" /> |     <PackageReference Include="Core.Adapters.Lib" Version="1.0.1" /> | ||||||
|     <PackageReference Include="BuildingBlocks.Library" Version="1.0.0" /> |     <PackageReference Include="Lib.Architecture.BuildingBlocks" Version="1.0.0" /> | ||||||
|     <PackageReference Include="Refit" Version="8.0.0" /> |     <PackageReference Include="Refit" Version="8.0.0" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|         private readonly IComponentHandler<CreateProductRequest> createProductHandler; |         private readonly IComponentHandler<CreateProductRequest> createProductHandler; | ||||||
|         private readonly IComponentHandler<UpdateProductRequest> updateProductHandler; |         private readonly IComponentHandler<UpdateProductRequest> updateProductHandler; | ||||||
|         private readonly IComponentHandler<ChangeProductStatusRequest> changeProductStatusHandler; |         private readonly IComponentHandler<ChangeProductStatusRequest> changeProductStatusHandler; | ||||||
|  |         private readonly IComponentHandler<DeleteProductRequest> deleteProductHandler; | ||||||
|         private readonly IProductPort port; |         private readonly IProductPort port; | ||||||
|  |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @@ -36,6 +37,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             IComponentHandler<CreateProductRequest> createProductHandler, |             IComponentHandler<CreateProductRequest> createProductHandler, | ||||||
|             IComponentHandler<UpdateProductRequest> updateProductHandler, |             IComponentHandler<UpdateProductRequest> updateProductHandler, | ||||||
|             IComponentHandler<ChangeProductStatusRequest> changeProductStatusHandler, |             IComponentHandler<ChangeProductStatusRequest> changeProductStatusHandler, | ||||||
|  |             IComponentHandler<DeleteProductRequest> deleteProductHandler, | ||||||
|             IProductPort port |             IProductPort port | ||||||
|             ) |             ) | ||||||
|         { |         { | ||||||
| @@ -45,6 +47,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             this.getAllProductsHandler = getAllProductsHandler; |             this.getAllProductsHandler = getAllProductsHandler; | ||||||
|             this.getProductHandler = getProductHandler; |             this.getProductHandler = getProductHandler; | ||||||
|             this.getAllProductsByListHandler = getAllProductsByListHandler; |             this.getAllProductsByListHandler = getAllProductsByListHandler; | ||||||
|  |             this.deleteProductHandler = deleteProductHandler; | ||||||
|             this.port = port; |             this.port = port; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -165,6 +168,15 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Changes the status of the Product. |         /// Changes the status of the Product. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|  |         /// <param name="request">The request containing the product ID and new ProductStatus.</param> | ||||||
|  |         /// <returns>The <see cref="ProductAdapter"/> updated entity.</returns> | ||||||
|  |         /// <response code="200">The Product updates.</response> | ||||||
|  |         /// <response code="204">The Product not found.</response> | ||||||
|  |         /// <response code="400">The Product could not be updated.</response> | ||||||
|  |         /// <response code="401">The Product could not be updated.</response> | ||||||
|  |         /// <response code="412">The Product could not be updated.</response> | ||||||
|  |         /// <response code="422">The Product could not be updated.</response> | ||||||
|  |         /// <response code="500">The service internal error.</response> | ||||||
|         [HttpPatch] |         [HttpPatch] | ||||||
|         [Route("ChangeStatus")] |         [Route("ChangeStatus")] | ||||||
|         [ProducesResponseType(StatusCodes.Status200OK)] |         [ProducesResponseType(StatusCodes.Status200OK)] | ||||||
| @@ -183,5 +195,38 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|  |  | ||||||
|             return port.ViewModel; |             return port.ViewModel; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Deletes a Product by its MongoDB identifier. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="request">The request containing the product ID to delete.</param> | ||||||
|  |         /// <param name="cancellationToken">Cancellation token for the asynchronous operation.</param> | ||||||
|  |         /// <returns>The <see cref="IActionResult"/> representing the result of the service call.</returns> | ||||||
|  |         /// <response code="200">The Product deleted successfully.</response> | ||||||
|  |         /// <response code="204">No content if the Product was not found.</response> | ||||||
|  |         /// <response code="400">Bad request if the Product ID is missing or invalid.</response> | ||||||
|  |         /// <response code="401">Unauthorized if the user is not authenticated.</response> | ||||||
|  |         /// <response code="412">Precondition failed if the request does not meet expected conditions.</response> | ||||||
|  |         /// <response code="422">Unprocessable entity if the request cannot be processed.</response> | ||||||
|  |         /// <response code="500">Internal server error if an unexpected error occurs.</response> | ||||||
|  |         [HttpDelete("Delete")] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status200OK)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status204NoContent)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status400BadRequest)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status401Unauthorized)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status412PreconditionFailed)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status422UnprocessableEntity)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status500InternalServerError)] | ||||||
|  |         public async Task<IActionResult> DeleteProductAsync([FromBody] DeleteProductRequest request, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             if (string.IsNullOrEmpty(request.Id)) | ||||||
|  |             { | ||||||
|  |                 return BadRequest("Invalid Product identifier"); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             await deleteProductHandler.ExecuteAsync(request, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |             return port.ViewModel; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| }  | }  | ||||||
| @@ -2,6 +2,7 @@ | |||||||
| using Core.Adapters.Lib; | using Core.Adapters.Lib; | ||||||
| using Core.Inventory.Application.UseCases.Tag.Input; | using Core.Inventory.Application.UseCases.Tag.Input; | ||||||
| using Core.Inventory.Application.UseCases.Tag.Ports; | using Core.Inventory.Application.UseCases.Tag.Ports; | ||||||
|  | using Core.Inventory.Application.UseCases.TagType.Input; | ||||||
| using Lib.Architecture.BuildingBlocks; | using Lib.Architecture.BuildingBlocks; | ||||||
| using Microsoft.AspNetCore.Authorization; | using Microsoft.AspNetCore.Authorization; | ||||||
| using Microsoft.AspNetCore.Mvc; | using Microsoft.AspNetCore.Mvc; | ||||||
| @@ -26,6 +27,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|         private readonly IComponentHandler<ChangeTagStatusRequest> changeTagStatusHandler; |         private readonly IComponentHandler<ChangeTagStatusRequest> changeTagStatusHandler; | ||||||
|         private readonly IComponentHandler<AddParentTagToTagRequest> addParentTagToTagHandler; |         private readonly IComponentHandler<AddParentTagToTagRequest> addParentTagToTagHandler; | ||||||
|         private readonly IComponentHandler<RemoveParentTagFromTagRequest> removeParentTagFromTagUserHandler; |         private readonly IComponentHandler<RemoveParentTagFromTagRequest> removeParentTagFromTagUserHandler; | ||||||
|  |         private readonly IComponentHandler<DeleteTagRequest> deleteTagHandler; | ||||||
|         private readonly ITagPort port; |         private readonly ITagPort port; | ||||||
|  |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @@ -40,6 +42,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             IComponentHandler<ChangeTagStatusRequest> changeTagStatusHandler, |             IComponentHandler<ChangeTagStatusRequest> changeTagStatusHandler, | ||||||
|             IComponentHandler<AddParentTagToTagRequest> addParentTagToTagHandler, |             IComponentHandler<AddParentTagToTagRequest> addParentTagToTagHandler, | ||||||
|             IComponentHandler<RemoveParentTagFromTagRequest> removeParentTagFromTagUserHandler, |             IComponentHandler<RemoveParentTagFromTagRequest> removeParentTagFromTagUserHandler, | ||||||
|  |             IComponentHandler<DeleteTagRequest> deleteTagHandler, | ||||||
|             ITagPort port |             ITagPort port | ||||||
|             ) |             ) | ||||||
|         { |         { | ||||||
| @@ -51,6 +54,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             this.getAllTagsByListHandler = getAllTagsByListHandler; |             this.getAllTagsByListHandler = getAllTagsByListHandler; | ||||||
|             this.addParentTagToTagHandler = addParentTagToTagHandler; |             this.addParentTagToTagHandler = addParentTagToTagHandler; | ||||||
|             this.removeParentTagFromTagUserHandler = removeParentTagFromTagUserHandler; |             this.removeParentTagFromTagUserHandler = removeParentTagFromTagUserHandler; | ||||||
|  |             this.deleteTagHandler = deleteTagHandler; | ||||||
|             this.port = port; |             this.port = port; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -235,5 +239,23 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|  |  | ||||||
|             return port.ViewModel; |             return port.ViewModel; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Deletes a full Tag by identifier. | ||||||
|  |         /// </summary> | ||||||
|  |         [HttpDelete("Delete")] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status200OK)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status204NoContent)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status401Unauthorized)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status412PreconditionFailed)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status422UnprocessableEntity)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status500InternalServerError)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status400BadRequest)] | ||||||
|  |         public async Task<IActionResult> UpdateTagAsync([FromBody] DeleteTagRequest request, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             await deleteTagHandler.ExecuteAsync(request, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |             return port.ViewModel; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|         private readonly IComponentHandler<CreateTagOverrideRequest> createTagOverrideHandler; |         private readonly IComponentHandler<CreateTagOverrideRequest> createTagOverrideHandler; | ||||||
|         private readonly IComponentHandler<UpdateTagOverrideRequest> updateTagOverrideHandler; |         private readonly IComponentHandler<UpdateTagOverrideRequest> updateTagOverrideHandler; | ||||||
|         private readonly IComponentHandler<ChangeTagOverrideStatusRequest> changeTagOverrideStatusHandler; |         private readonly IComponentHandler<ChangeTagOverrideStatusRequest> changeTagOverrideStatusHandler; | ||||||
|  |         private readonly IComponentHandler<DeleteTagOverrideRequest> deleteTagOverrideHandler; | ||||||
|         private readonly ITagOverridePort port; |         private readonly ITagOverridePort port; | ||||||
|  |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @@ -36,6 +37,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             IComponentHandler<CreateTagOverrideRequest> createTagOverrideHandler, |             IComponentHandler<CreateTagOverrideRequest> createTagOverrideHandler, | ||||||
|             IComponentHandler<UpdateTagOverrideRequest> updateTagOverrideHandler, |             IComponentHandler<UpdateTagOverrideRequest> updateTagOverrideHandler, | ||||||
|             IComponentHandler<ChangeTagOverrideStatusRequest> changeTagOverrideStatusHandler, |             IComponentHandler<ChangeTagOverrideStatusRequest> changeTagOverrideStatusHandler, | ||||||
|  |             IComponentHandler<DeleteTagOverrideRequest> deleteTagOverrideHandler, | ||||||
|             ITagOverridePort port |             ITagOverridePort port | ||||||
|             ) |             ) | ||||||
|         { |         { | ||||||
| @@ -45,6 +47,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             this.getAllTagOverridesHandler = getAllTagOverridesHandler; |             this.getAllTagOverridesHandler = getAllTagOverridesHandler; | ||||||
|             this.getTagOverrideHandler = getTagOverrideHandler; |             this.getTagOverrideHandler = getTagOverrideHandler; | ||||||
|             this.getAllTagOverridesByListHandler = getAllTagOverridesByListHandler; |             this.getAllTagOverridesByListHandler = getAllTagOverridesByListHandler; | ||||||
|  |             this.deleteTagOverrideHandler = deleteTagOverrideHandler; | ||||||
|             this.port = port; |             this.port = port; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -183,5 +186,23 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|  |  | ||||||
|             return port.ViewModel; |             return port.ViewModel; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Deletes a full TagOverride by identifier. | ||||||
|  |         /// </summary> | ||||||
|  |         [HttpDelete("Delete")] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status200OK)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status204NoContent)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status401Unauthorized)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status412PreconditionFailed)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status422UnprocessableEntity)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status500InternalServerError)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status400BadRequest)] | ||||||
|  |         public async Task<IActionResult> UpdateTagOverrideAsync([FromBody] DeleteTagOverrideRequest request, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             await deleteTagOverrideHandler.ExecuteAsync(request, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |             return port.ViewModel; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|         private readonly IComponentHandler<CreateTagTypeRequest> createTagTypeHandler; |         private readonly IComponentHandler<CreateTagTypeRequest> createTagTypeHandler; | ||||||
|         private readonly IComponentHandler<UpdateTagTypeRequest> updateTagTypeHandler; |         private readonly IComponentHandler<UpdateTagTypeRequest> updateTagTypeHandler; | ||||||
|         private readonly IComponentHandler<ChangeTagTypeStatusRequest> changeTagTypeStatusHandler; |         private readonly IComponentHandler<ChangeTagTypeStatusRequest> changeTagTypeStatusHandler; | ||||||
|  |         private readonly IComponentHandler<DeleteTagTypeRequest> deleteTagTypeHandler; | ||||||
|         private readonly ITagTypePort port; |         private readonly ITagTypePort port; | ||||||
|  |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @@ -36,6 +37,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             IComponentHandler<CreateTagTypeRequest> createTagTypeHandler, |             IComponentHandler<CreateTagTypeRequest> createTagTypeHandler, | ||||||
|             IComponentHandler<UpdateTagTypeRequest> updateTagTypeHandler, |             IComponentHandler<UpdateTagTypeRequest> updateTagTypeHandler, | ||||||
|             IComponentHandler<ChangeTagTypeStatusRequest> changeTagTypeStatusHandler, |             IComponentHandler<ChangeTagTypeStatusRequest> changeTagTypeStatusHandler, | ||||||
|  |             IComponentHandler<DeleteTagTypeRequest> deleteTagTypeHandler, | ||||||
|             ITagTypePort port |             ITagTypePort port | ||||||
|             ) |             ) | ||||||
|         { |         { | ||||||
| @@ -45,6 +47,7 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|             this.getAllTagTypesHandler = getAllTagTypesHandler; |             this.getAllTagTypesHandler = getAllTagTypesHandler; | ||||||
|             this.getTagTypeHandler = getTagTypeHandler; |             this.getTagTypeHandler = getTagTypeHandler; | ||||||
|             this.getAllTagTypesByListHandler = getAllTagTypesByListHandler; |             this.getAllTagTypesByListHandler = getAllTagTypesByListHandler; | ||||||
|  |             this.deleteTagTypeHandler = deleteTagTypeHandler; | ||||||
|             this.port = port; |             this.port = port; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -183,5 +186,23 @@ namespace Core.Inventory.Service.API.Controllers | |||||||
|  |  | ||||||
|             return port.ViewModel; |             return port.ViewModel; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Deletes a full TagType by identifier. | ||||||
|  |         /// </summary> | ||||||
|  |         [HttpDelete("Delete")] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status200OK)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status204NoContent)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status401Unauthorized)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status412PreconditionFailed)] | ||||||
|  |         [ProducesResponseType(typeof(Notification), StatusCodes.Status422UnprocessableEntity)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status500InternalServerError)] | ||||||
|  |         [ProducesResponseType(StatusCodes.Status400BadRequest)] | ||||||
|  |         public async Task<IActionResult> UpdateTagTypeAsync([FromBody] DeleteTagTypeRequest request, CancellationToken cancellationToken = default) | ||||||
|  |         { | ||||||
|  |             await deleteTagTypeHandler.ExecuteAsync(request, cancellationToken).ConfigureAwait(false); | ||||||
|  |  | ||||||
|  |             return port.ViewModel; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ | |||||||
|  |  | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="Asp.Versioning.Mvc.ApiExplorer" Version="8.1.0" /> |     <PackageReference Include="Asp.Versioning.Mvc.ApiExplorer" Version="8.1.0" /> | ||||||
|     <PackageReference Include="Core.Blueprint.Logging" Version="1.0.1" /> |     <PackageReference Include="Core.Blueprint.Logging" Version="1.0.0" /> | ||||||
|     <PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2" /> |     <PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -108,6 +108,10 @@ namespace Core.Inventory.Service.API.Extensions | |||||||
|             services.AddScoped<IValidator<ChangeTagTypeStatusRequest>, ChangeTagTypeStatusValidator>(); |             services.AddScoped<IValidator<ChangeTagTypeStatusRequest>, ChangeTagTypeStatusValidator>(); | ||||||
|             services.AddScoped<IComponentHandler<ChangeTagTypeStatusRequest>, TagTypeHandler>(); |             services.AddScoped<IComponentHandler<ChangeTagTypeStatusRequest>, TagTypeHandler>(); | ||||||
|  |  | ||||||
|  |             services.AddValidatorsFromAssemblyContaining<DeleteTagTypeValidator>(); | ||||||
|  |             services.AddScoped<IValidator<DeleteTagTypeRequest>, DeleteTagTypeValidator>(); | ||||||
|  |             services.AddScoped<IComponentHandler<DeleteTagTypeRequest>, TagTypeHandler>(); | ||||||
|  |  | ||||||
|             #endregion |             #endregion | ||||||
|  |  | ||||||
|             #region Tag Services |             #region Tag Services | ||||||
| @@ -135,6 +139,10 @@ namespace Core.Inventory.Service.API.Extensions | |||||||
|             services.AddScoped<IComponentHandler<AddParentTagToTagRequest>, TagHandler>(); |             services.AddScoped<IComponentHandler<AddParentTagToTagRequest>, TagHandler>(); | ||||||
|             services.AddScoped<IComponentHandler<RemoveParentTagFromTagRequest>, TagHandler>(); |             services.AddScoped<IComponentHandler<RemoveParentTagFromTagRequest>, TagHandler>(); | ||||||
|  |  | ||||||
|  |             services.AddValidatorsFromAssemblyContaining<DeleteTagValidator>(); | ||||||
|  |             services.AddScoped<IValidator<DeleteTagRequest>, DeleteTagValidator>(); | ||||||
|  |             services.AddScoped<IComponentHandler<DeleteTagRequest>, TagHandler>(); | ||||||
|  |  | ||||||
|             #endregion |             #endregion | ||||||
|  |  | ||||||
|             #region TagOverride Services |             #region TagOverride Services | ||||||
| @@ -159,6 +167,10 @@ namespace Core.Inventory.Service.API.Extensions | |||||||
|             services.AddScoped<IValidator<ChangeTagOverrideStatusRequest>, ChangeTagOverrideStatusValidator>(); |             services.AddScoped<IValidator<ChangeTagOverrideStatusRequest>, ChangeTagOverrideStatusValidator>(); | ||||||
|             services.AddScoped<IComponentHandler<ChangeTagOverrideStatusRequest>, TagOverrideHandler>(); |             services.AddScoped<IComponentHandler<ChangeTagOverrideStatusRequest>, TagOverrideHandler>(); | ||||||
|  |  | ||||||
|  |             services.AddValidatorsFromAssemblyContaining<DeleteTagOverrideValidator>(); | ||||||
|  |             services.AddScoped<IValidator<DeleteTagOverrideRequest>, DeleteTagOverrideValidator>(); | ||||||
|  |             services.AddScoped<IComponentHandler<DeleteTagOverrideRequest>, TagOverrideHandler>(); | ||||||
|  |  | ||||||
|             #endregion |             #endregion | ||||||
|  |  | ||||||
|             #region Product Services |             #region Product Services | ||||||
| @@ -183,6 +195,10 @@ namespace Core.Inventory.Service.API.Extensions | |||||||
|             services.AddScoped<IValidator<ChangeProductStatusRequest>, ChangeProductStatusValidator>(); |             services.AddScoped<IValidator<ChangeProductStatusRequest>, ChangeProductStatusValidator>(); | ||||||
|             services.AddScoped<IComponentHandler<ChangeProductStatusRequest>, ProductHandler>(); |             services.AddScoped<IComponentHandler<ChangeProductStatusRequest>, ProductHandler>(); | ||||||
|  |  | ||||||
|  |             services.AddValidatorsFromAssemblyContaining<DeleteProductValidator>(); | ||||||
|  |             services.AddScoped<IValidator<DeleteProductRequest>, DeleteProductValidator>(); | ||||||
|  |             services.AddScoped<IComponentHandler<DeleteProductRequest>, ProductHandler>(); | ||||||
|  |  | ||||||
|             #endregion |             #endregion | ||||||
|  |  | ||||||
|             return services; |             return services; | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | # ===== Build stage ===== | ||||||
|  | FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build | ||||||
|  | WORKDIR /src | ||||||
|  |  | ||||||
|  | # Usaremos la config de NuGet de la raíz (BaGet + nuget.org) | ||||||
|  | COPY nuget.config ./ | ||||||
|  |  | ||||||
|  | # Copiamos SOLO los .csproj primero (mejor caché en restore) | ||||||
|  | COPY Core.Inventory.Service.API/Core.Inventory.Service.API.csproj Core.Inventory.Service.API/ | ||||||
|  | COPY Core.Inventory.Application/Core.Inventory.Application.csproj Core.Inventory.Application/ | ||||||
|  | COPY Core.Inventory.External/Core.Inventory.External.csproj Core.Inventory.External/ | ||||||
|  |  | ||||||
|  | # Restaura con tu nuget.config | ||||||
|  | RUN dotnet restore Core.Inventory.Service.API/Core.Inventory.Service.API.csproj --configfile ./nuget.config | ||||||
|  |  | ||||||
|  | # Ahora sí, copia todo el código | ||||||
|  | COPY . . | ||||||
|  |  | ||||||
|  | # Publica artefactos (sin apphost para imagen más pequeña) | ||||||
|  | ARG BUILD_CONFIGURATION=Release | ||||||
|  | RUN dotnet publish Core.Inventory.Service.API/Core.Inventory.Service.API.csproj \ | ||||||
|  |     -c $BUILD_CONFIGURATION -o /app/out /p:UseAppHost=false | ||||||
|  |  | ||||||
|  | # ===== Runtime stage ===== | ||||||
|  | FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS runtime | ||||||
|  | WORKDIR /app | ||||||
|  |  | ||||||
|  | # Copiamos el publish | ||||||
|  | COPY --from=build /app/out . | ||||||
|  |  | ||||||
|  | # Variables típicas (ajústalas luego en compose) | ||||||
|  | ENV ASPNETCORE_URLS=http://+:8080 \ | ||||||
|  |     ASPNETCORE_ENVIRONMENT=Production | ||||||
|  |  | ||||||
|  | # Exponemos el puerto HTTP | ||||||
|  | EXPOSE 8080 | ||||||
|  |  | ||||||
|  | # Opcional: healthcheck si tienes /health | ||||||
|  | # HEALTHCHECK --interval=30s --timeout=5s --retries=5 \ | ||||||
|  | #   CMD wget -qO- http://localhost:8080/health || exit 1 | ||||||
|  |  | ||||||
|  | ENTRYPOINT ["dotnet", "Core.Inventory.Service.API.dll"] | ||||||
							
								
								
									
										9
									
								
								nuget.config
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								nuget.config
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <configuration> | ||||||
|  |   <packageSources> | ||||||
|  |     <!-- Tu BaGet primero --> | ||||||
|  |     <add key="BaGet" value="https://nuget.dream-views.com/v3/index.json" protocolVersion="3" /> | ||||||
|  |     <!-- NuGet oficial como fallback (si quieres) --> | ||||||
|  |     <add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" /> | ||||||
|  |   </packageSources> | ||||||
|  | </configuration> | ||||||
		Reference in New Issue
	
	Block a user