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? Representation { get; set; } | ||||
|         public string? MaintenanceNotes { get; set; } | ||||
|  | ||||
|         public Dimensions Dimensions { get; set; } = new(); | ||||
|  | ||||
|         public List<string>? VariantIds { get; set; } | ||||
|         public string Icon { get; set; } = null!; | ||||
|  | ||||
|         public bool Validate() | ||||
|         { | ||||
|             return !string.IsNullOrWhiteSpace(ModelName) && | ||||
|   | ||||
| @@ -21,10 +21,10 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Base | ||||
|         public string? BaseDescription { get; set; } | ||||
|         public string? Representation { get; set; } | ||||
|         public string? MaintenanceNotes { get; set; } | ||||
|  | ||||
|         public Dimensions Dimensions { get; set; } = new(); | ||||
|  | ||||
|         public List<string>? VariantIds { get; set; } | ||||
|         public string Icon { get; set; } = null!; | ||||
|  | ||||
|         public bool Validate() | ||||
|         { | ||||
|             return !string.IsNullOrWhiteSpace(_Id) | ||||
|   | ||||
| @@ -13,15 +13,13 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Variant | ||||
|         public string Name { get; set; } = null!; | ||||
|         public string Color { get; set; } = null!; | ||||
|         public string? Line { get; set; } | ||||
|  | ||||
|         public decimal Price { get; set; } | ||||
|         public string Currency { get; set; } = "USD"; | ||||
|         public int Stock { get; set; } | ||||
|  | ||||
|         public string CategoryId { get; set; } = string.Empty; | ||||
|         public string ProviderId { get; set; } = string.Empty; | ||||
|  | ||||
|         public Dictionary<string, string> Attributes { get; set; } = []; | ||||
|         public string Icon { get; set; } = null!; | ||||
|  | ||||
|         public bool Validate() | ||||
|         { | ||||
|   | ||||
| @@ -23,11 +23,10 @@ namespace Core.Inventory.Application.UseCases.Inventory.Input.Variant | ||||
|         public int Stock { get; set; } | ||||
|         public decimal Price { get; set; } | ||||
|         public string Currency { get; set; } = "USD"; | ||||
|  | ||||
|         public string CategoryId { get; set; } = string.Empty!; | ||||
|         public string ProviderId { get; set; } = string.Empty!; | ||||
|  | ||||
|         public Dictionary<string, string> Attributes { get; set; } = []; | ||||
|         public string Icon { get; set; } = null!; | ||||
|  | ||||
|         public bool Validate() | ||||
|         { | ||||
|   | ||||
| @@ -94,7 +94,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | ||||
|                         Depth = command.Dimensions.Depth, | ||||
|                         Height = command.Dimensions.Height, | ||||
|                         Width = command.Dimensions.Width | ||||
|                     } | ||||
|                     }, | ||||
|                     Icon = command.Icon | ||||
|                 }; | ||||
|  | ||||
|                 var result = await _inventoryDALService.CreateFurnitureBaseAsync(request, cancellationToken); | ||||
| @@ -133,7 +134,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | ||||
|                         Depth = command.Dimensions.Depth, | ||||
|                         Height = command.Dimensions.Height, | ||||
|                         Width = command.Dimensions.Width | ||||
|                     } | ||||
|                     }, | ||||
|                     Icon = command.Icon | ||||
|                 }; | ||||
|  | ||||
|                 var result = await _inventoryDALService.UpdateFurnitureBaseAsync(command.Id, request, cancellationToken); | ||||
| @@ -226,7 +228,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | ||||
|                     ModelId = command.ModelId, | ||||
|                     Name = command.Name, | ||||
|                     Price = command.Price, | ||||
|                     ProviderId  = command.ProviderId | ||||
|                     ProviderId  = command.ProviderId, | ||||
|                     Icon = command.Icon | ||||
|                 }; | ||||
|                 var result = await _inventoryDALService.CreateFurnitureVariantAsync(request, cancellationToken); | ||||
|                 _variantPort.Success(result); | ||||
| @@ -260,7 +263,8 @@ namespace Core.Inventory.Application.UseCases.Inventory | ||||
|                     ModelId = command.ModelId, | ||||
|                     Name = command.Name, | ||||
|                     Price = command.Price, | ||||
|                     ProviderId = command.ProviderId | ||||
|                     ProviderId = command.ProviderId, | ||||
|                     Icon = command.Icon | ||||
|                 }; | ||||
|                 var result = await _inventoryDALService.UpdateFurnitureVariantAsync(command.Id, request, cancellationToken); | ||||
|                 _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); | ||||
|         } | ||||
|         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 ProductName { 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 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 ProductName { 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 bool Validate() | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| using Core.Adapters.Lib.Inventory; | ||||
| using Core.Inventory.Application.UseCases.Product.Adapter; | ||||
| using Lib.Architecture.BuildingBlocks; | ||||
|  | ||||
| namespace Core.Inventory.Application.UseCases.Product.Ports | ||||
| @@ -6,6 +7,7 @@ namespace Core.Inventory.Application.UseCases.Product.Ports | ||||
|     public interface IProductPort : IBasePort, | ||||
|         ICommandSuccessPort<ProductAdapter>, | ||||
|         ICommandSuccessPort<List<ProductAdapter>>, | ||||
|         ICommandSuccessPort<DeleteProductResponseAdapter>, | ||||
|         INoContentPort, IBusinessErrorPort, ITimeoutPort, IValidationErrorPort, | ||||
|         INotFoundPort, IForbiddenPort, IUnauthorizedPort, IInternalServerErrorPort, | ||||
|         IBadRequestPort | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| 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.Ports; | ||||
| using Core.Inventory.External.Clients; | ||||
| @@ -15,13 +16,15 @@ namespace Core.Inventory.Application.UseCases.Product | ||||
|         IComponentHandler<GetAllProductsByListRequest>, | ||||
|         IComponentHandler<UpdateProductRequest>, | ||||
|         IComponentHandler<GetProductRequest>, | ||||
|         IComponentHandler<CreateProductRequest> | ||||
|         IComponentHandler<CreateProductRequest>, | ||||
|         IComponentHandler<DeleteProductRequest> | ||||
|     { | ||||
|         private readonly IProductPort _port; | ||||
|         private readonly IValidator<ChangeProductStatusRequest> _changeProductStatusValidator; | ||||
|         private readonly IValidator<CreateProductRequest> _registerProductValidator; | ||||
|         private readonly IValidator<UpdateProductRequest> _updateProductValidator; | ||||
|         private readonly IValidator<GetAllProductsByListRequest> _productsByListValidator; | ||||
|         private readonly IValidator<DeleteProductRequest> _deleteProductValidator; | ||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||
|  | ||||
|         public ProductHandler( | ||||
| @@ -30,6 +33,7 @@ namespace Core.Inventory.Application.UseCases.Product | ||||
|             IValidator<CreateProductRequest> registerProductValidator, | ||||
|             IValidator<UpdateProductRequest> updateProductValidator, | ||||
|             IValidator<GetAllProductsByListRequest> productsByListValidator, | ||||
|             IValidator<DeleteProductRequest> deleteProductValidator, | ||||
|             IInventoryServiceClient inventoryDALService) | ||||
|         { | ||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||
| @@ -38,6 +42,7 @@ namespace Core.Inventory.Application.UseCases.Product | ||||
|             _updateProductValidator = updateProductValidator ?? throw new ArgumentNullException(nameof(updateProductValidator)); | ||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||
|             _productsByListValidator = productsByListValidator ?? throw new ArgumentNullException(nameof(productsByListValidator)); | ||||
|             _deleteProductValidator = deleteProductValidator ?? throw new ArgumentNullException(nameof(deleteProductValidator)); | ||||
|         } | ||||
|  | ||||
|         public async ValueTask ExecuteAsync(GetProductRequest command, CancellationToken cancellationToken = default) | ||||
| @@ -153,7 +158,7 @@ namespace Core.Inventory.Application.UseCases.Product | ||||
|                     TenantId = command.TenantId, | ||||
|                     ProductName = command.ProductName, | ||||
|                     Description = command.Description, | ||||
|                     Status = command.Status, | ||||
|                     ProductStatus = command.ProductStatus, | ||||
|                     TagIds = command.TagIds | ||||
|                 }; | ||||
|  | ||||
| @@ -191,7 +196,7 @@ namespace Core.Inventory.Application.UseCases.Product | ||||
|                     TenantId = command.TenantId, | ||||
|                     ProductName = command.ProductName, | ||||
|                     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() | ||||
|                 }; | ||||
|  | ||||
| @@ -210,5 +215,33 @@ namespace Core.Inventory.Application.UseCases.Product | ||||
|                 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<CreateTagRequest>, | ||||
|         IComponentHandler<AddParentTagToTagRequest>, | ||||
|         IComponentHandler<RemoveParentTagFromTagRequest> | ||||
|         IComponentHandler<RemoveParentTagFromTagRequest>, | ||||
|         IComponentHandler<DeleteTagRequest> | ||||
|     { | ||||
|         private readonly ITagPort _port; | ||||
|         private readonly IValidator<ChangeTagStatusRequest> _changeTagStatusValidator; | ||||
| @@ -25,6 +26,7 @@ namespace Core.Inventory.Application.UseCases.Tag | ||||
|         private readonly IValidator<UpdateTagRequest> _updateTagValidator; | ||||
|         private readonly IValidator<GetAllTagsByListRequest> _TagsByListValidator; | ||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||
|         private readonly IValidator<DeleteTagRequest> _deleteTagValidator; | ||||
|  | ||||
|         public TagHandler( | ||||
|             ITagPort port, | ||||
| @@ -32,6 +34,7 @@ namespace Core.Inventory.Application.UseCases.Tag | ||||
|             IValidator<CreateTagRequest> registerTagValidator, | ||||
|             IValidator<UpdateTagRequest> updateTagValidator, | ||||
|             IValidator<GetAllTagsByListRequest> TagsByListValidator, | ||||
|             IValidator<DeleteTagRequest> deleteTagValidator, | ||||
|             IInventoryServiceClient inventoryDALService) | ||||
|         { | ||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||
| @@ -40,6 +43,7 @@ namespace Core.Inventory.Application.UseCases.Tag | ||||
|             _updateTagValidator = updateTagValidator ?? throw new ArgumentNullException(nameof(updateTagValidator)); | ||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||
|             _TagsByListValidator = TagsByListValidator ?? throw new ArgumentNullException(nameof(TagsByListValidator)); | ||||
|             _deleteTagValidator = deleteTagValidator ?? throw new ArgumentNullException(nameof(deleteTagValidator)); | ||||
|         } | ||||
|  | ||||
|         public async ValueTask ExecuteAsync(GetTagRequest command, CancellationToken cancellationToken = default) | ||||
| @@ -262,5 +266,33 @@ namespace Core.Inventory.Application.UseCases.Tag | ||||
|                 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<UpdateTagOverrideRequest>, | ||||
|         IComponentHandler<GetTagOverrideRequest>, | ||||
|         IComponentHandler<CreateTagOverrideRequest> | ||||
|         IComponentHandler<CreateTagOverrideRequest>, | ||||
|         IComponentHandler<DeleteTagOverrideRequest> | ||||
|     { | ||||
|         private readonly ITagOverridePort _port; | ||||
|         private readonly IValidator<ChangeTagOverrideStatusRequest> _changeTagOverrideStatusValidator; | ||||
| @@ -23,6 +24,7 @@ namespace Core.Inventory.Application.UseCases.TagOverride | ||||
|         private readonly IValidator<UpdateTagOverrideRequest> _updateTagOverrideValidator; | ||||
|         private readonly IValidator<GetAllTagOverridesByListRequest> _TagOverridesByListValidator; | ||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||
|         private readonly IValidator<DeleteTagOverrideRequest> _deleteTagOverrideValidator; | ||||
|  | ||||
|         public TagOverrideHandler( | ||||
|             ITagOverridePort port, | ||||
| @@ -30,6 +32,7 @@ namespace Core.Inventory.Application.UseCases.TagOverride | ||||
|             IValidator<CreateTagOverrideRequest> registerTagOverrideValidator, | ||||
|             IValidator<UpdateTagOverrideRequest> updateTagOverrideValidator, | ||||
|             IValidator<GetAllTagOverridesByListRequest> TagOverridesByListValidator, | ||||
|             IValidator<DeleteTagOverrideRequest> deleteTagOverrideValidator, | ||||
|             IInventoryServiceClient inventoryDALService) | ||||
|         { | ||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||
| @@ -38,6 +41,7 @@ namespace Core.Inventory.Application.UseCases.TagOverride | ||||
|             _updateTagOverrideValidator = updateTagOverrideValidator ?? throw new ArgumentNullException(nameof(updateTagOverrideValidator)); | ||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||
|             _TagOverridesByListValidator = TagOverridesByListValidator ?? throw new ArgumentNullException(nameof(TagOverridesByListValidator)); | ||||
|             _deleteTagOverrideValidator = deleteTagOverrideValidator ?? throw new ArgumentNullException(nameof(deleteTagOverrideValidator)); | ||||
|         } | ||||
|  | ||||
|         public async ValueTask ExecuteAsync(GetTagOverrideRequest command, CancellationToken cancellationToken = default) | ||||
| @@ -208,5 +212,33 @@ namespace Core.Inventory.Application.UseCases.TagOverride | ||||
|                 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<UpdateTagTypeRequest>, | ||||
|         IComponentHandler<GetTagTypeRequest>, | ||||
|         IComponentHandler<CreateTagTypeRequest> | ||||
|         IComponentHandler<CreateTagTypeRequest>, | ||||
|         IComponentHandler<DeleteTagTypeRequest> | ||||
|     { | ||||
|         private readonly ITagTypePort _port; | ||||
|         private readonly IValidator<ChangeTagTypeStatusRequest> _changeTagTypeStatusValidator; | ||||
|         private readonly IValidator<CreateTagTypeRequest> _registerTagTypeValidator; | ||||
|         private readonly IValidator<UpdateTagTypeRequest> _updateTagTypeValidator; | ||||
|         private readonly IValidator<GetAllTagTypesByListRequest> _TagTypesByListValidator; | ||||
|         private readonly IValidator<DeleteTagTypeRequest> _deleteTagTypeValidator; | ||||
|         private readonly IInventoryServiceClient _inventoryServiceClient; | ||||
|  | ||||
|         public TagTypeHandler( | ||||
| @@ -30,6 +32,7 @@ namespace Core.Inventory.Application.UseCases.TagType | ||||
|             IValidator<CreateTagTypeRequest> registerTagTypeValidator, | ||||
|             IValidator<UpdateTagTypeRequest> updateTagTypeValidator, | ||||
|             IValidator<GetAllTagTypesByListRequest> TagTypesByListValidator, | ||||
|             IValidator<DeleteTagTypeRequest> deleteTagTypeValidator, | ||||
|             IInventoryServiceClient inventoryDALService) | ||||
|         { | ||||
|             _port = port ?? throw new ArgumentNullException(nameof(port)); | ||||
| @@ -38,6 +41,7 @@ namespace Core.Inventory.Application.UseCases.TagType | ||||
|             _updateTagTypeValidator = updateTagTypeValidator ?? throw new ArgumentNullException(nameof(updateTagTypeValidator)); | ||||
|             _inventoryServiceClient = inventoryDALService ?? throw new ArgumentNullException(nameof(inventoryDALService)); | ||||
|             _TagTypesByListValidator = TagTypesByListValidator ?? throw new ArgumentNullException(nameof(TagTypesByListValidator)); | ||||
|             _deleteTagTypeValidator = deleteTagTypeValidator ?? throw new ArgumentNullException(nameof(deleteTagTypeValidator)); | ||||
|         } | ||||
|  | ||||
|         public async ValueTask ExecuteAsync(GetTagTypeRequest command, CancellationToken cancellationToken = default) | ||||
| @@ -210,5 +214,33 @@ namespace Core.Inventory.Application.UseCases.TagType | ||||
|                 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 List<string>? VariantIds { get; set; } | ||||
|         public string Icon { get; set; } = null!; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -17,5 +17,6 @@ | ||||
|         public string ProviderId { get; set; } = string.Empty!; | ||||
|  | ||||
|         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")] | ||||
|         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 | ||||
|  | ||||
|         #region Tag | ||||
| @@ -101,6 +104,9 @@ namespace Core.Inventory.External.Clients | ||||
|         [Delete("/api/v1/Tag/{tagId}/ParentTags/{parentTagId}/Remove")] | ||||
|         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 | ||||
|  | ||||
|         #region TagOverride | ||||
| @@ -123,6 +129,9 @@ namespace Core.Inventory.External.Clients | ||||
|         [Patch("/api/v1/TagOverride/{id}/{newStatus}/ChangeStatus")] | ||||
|         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 | ||||
|  | ||||
|         #region Product | ||||
| @@ -151,6 +160,9 @@ namespace Core.Inventory.External.Clients | ||||
|         [Delete("/api/v1/Product/{productId}/tags/{tagId}")] | ||||
|         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 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -10,8 +10,8 @@ namespace Core.Inventory.External.Clients.Requests | ||||
|         public string? BaseDescription { get; set; } | ||||
|         public string? Representation { get; set; } | ||||
|         public string? MaintenanceNotes { get; set; } | ||||
|  | ||||
|         public Dimensions Dimensions { get; set; } = new(); | ||||
|         public List<string>? VariantIds { get; set; } | ||||
|         public string Icon { get; set; } = null!; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -15,5 +15,7 @@ | ||||
|         public string ProviderId { get; set; } = string.Empty!; | ||||
|  | ||||
|         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 ProductName { 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>(); | ||||
|     } | ||||
| }  | ||||
| @@ -7,8 +7,8 @@ | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="Adapters.Lib" Version="1.0.11" /> | ||||
|     <PackageReference Include="BuildingBlocks.Library" Version="1.0.0" /> | ||||
|     <PackageReference Include="Core.Adapters.Lib" Version="1.0.1" /> | ||||
|     <PackageReference Include="Lib.Architecture.BuildingBlocks" Version="1.0.0" /> | ||||
|     <PackageReference Include="Refit" Version="8.0.0" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   | ||||
| @@ -24,6 +24,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|         private readonly IComponentHandler<CreateProductRequest> createProductHandler; | ||||
|         private readonly IComponentHandler<UpdateProductRequest> updateProductHandler; | ||||
|         private readonly IComponentHandler<ChangeProductStatusRequest> changeProductStatusHandler; | ||||
|         private readonly IComponentHandler<DeleteProductRequest> deleteProductHandler; | ||||
|         private readonly IProductPort port; | ||||
|  | ||||
|         /// <summary> | ||||
| @@ -36,6 +37,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             IComponentHandler<CreateProductRequest> createProductHandler, | ||||
|             IComponentHandler<UpdateProductRequest> updateProductHandler, | ||||
|             IComponentHandler<ChangeProductStatusRequest> changeProductStatusHandler, | ||||
|             IComponentHandler<DeleteProductRequest> deleteProductHandler, | ||||
|             IProductPort port | ||||
|             ) | ||||
|         { | ||||
| @@ -45,6 +47,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             this.getAllProductsHandler = getAllProductsHandler; | ||||
|             this.getProductHandler = getProductHandler; | ||||
|             this.getAllProductsByListHandler = getAllProductsByListHandler; | ||||
|             this.deleteProductHandler = deleteProductHandler; | ||||
|             this.port = port; | ||||
|         } | ||||
|  | ||||
| @@ -165,6 +168,15 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|         /// <summary> | ||||
|         /// Changes the status of the Product. | ||||
|         /// </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] | ||||
|         [Route("ChangeStatus")] | ||||
|         [ProducesResponseType(StatusCodes.Status200OK)] | ||||
| @@ -183,5 +195,38 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|  | ||||
|             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.Inventory.Application.UseCases.Tag.Input; | ||||
| using Core.Inventory.Application.UseCases.Tag.Ports; | ||||
| using Core.Inventory.Application.UseCases.TagType.Input; | ||||
| using Lib.Architecture.BuildingBlocks; | ||||
| using Microsoft.AspNetCore.Authorization; | ||||
| using Microsoft.AspNetCore.Mvc; | ||||
| @@ -26,6 +27,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|         private readonly IComponentHandler<ChangeTagStatusRequest> changeTagStatusHandler; | ||||
|         private readonly IComponentHandler<AddParentTagToTagRequest> addParentTagToTagHandler; | ||||
|         private readonly IComponentHandler<RemoveParentTagFromTagRequest> removeParentTagFromTagUserHandler; | ||||
|         private readonly IComponentHandler<DeleteTagRequest> deleteTagHandler; | ||||
|         private readonly ITagPort port; | ||||
|  | ||||
|         /// <summary> | ||||
| @@ -40,6 +42,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             IComponentHandler<ChangeTagStatusRequest> changeTagStatusHandler, | ||||
|             IComponentHandler<AddParentTagToTagRequest> addParentTagToTagHandler, | ||||
|             IComponentHandler<RemoveParentTagFromTagRequest> removeParentTagFromTagUserHandler, | ||||
|             IComponentHandler<DeleteTagRequest> deleteTagHandler, | ||||
|             ITagPort port | ||||
|             ) | ||||
|         { | ||||
| @@ -51,6 +54,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             this.getAllTagsByListHandler = getAllTagsByListHandler; | ||||
|             this.addParentTagToTagHandler = addParentTagToTagHandler; | ||||
|             this.removeParentTagFromTagUserHandler = removeParentTagFromTagUserHandler; | ||||
|             this.deleteTagHandler = deleteTagHandler; | ||||
|             this.port = port; | ||||
|         } | ||||
|  | ||||
| @@ -235,5 +239,23 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|  | ||||
|             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<UpdateTagOverrideRequest> updateTagOverrideHandler; | ||||
|         private readonly IComponentHandler<ChangeTagOverrideStatusRequest> changeTagOverrideStatusHandler; | ||||
|         private readonly IComponentHandler<DeleteTagOverrideRequest> deleteTagOverrideHandler; | ||||
|         private readonly ITagOverridePort port; | ||||
|  | ||||
|         /// <summary> | ||||
| @@ -36,6 +37,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             IComponentHandler<CreateTagOverrideRequest> createTagOverrideHandler, | ||||
|             IComponentHandler<UpdateTagOverrideRequest> updateTagOverrideHandler, | ||||
|             IComponentHandler<ChangeTagOverrideStatusRequest> changeTagOverrideStatusHandler, | ||||
|             IComponentHandler<DeleteTagOverrideRequest> deleteTagOverrideHandler, | ||||
|             ITagOverridePort port | ||||
|             ) | ||||
|         { | ||||
| @@ -45,6 +47,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             this.getAllTagOverridesHandler = getAllTagOverridesHandler; | ||||
|             this.getTagOverrideHandler = getTagOverrideHandler; | ||||
|             this.getAllTagOverridesByListHandler = getAllTagOverridesByListHandler; | ||||
|             this.deleteTagOverrideHandler = deleteTagOverrideHandler; | ||||
|             this.port = port; | ||||
|         } | ||||
|  | ||||
| @@ -183,5 +186,23 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|  | ||||
|             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<UpdateTagTypeRequest> updateTagTypeHandler; | ||||
|         private readonly IComponentHandler<ChangeTagTypeStatusRequest> changeTagTypeStatusHandler; | ||||
|         private readonly IComponentHandler<DeleteTagTypeRequest> deleteTagTypeHandler; | ||||
|         private readonly ITagTypePort port; | ||||
|  | ||||
|         /// <summary> | ||||
| @@ -36,6 +37,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             IComponentHandler<CreateTagTypeRequest> createTagTypeHandler, | ||||
|             IComponentHandler<UpdateTagTypeRequest> updateTagTypeHandler, | ||||
|             IComponentHandler<ChangeTagTypeStatusRequest> changeTagTypeStatusHandler, | ||||
|             IComponentHandler<DeleteTagTypeRequest> deleteTagTypeHandler, | ||||
|             ITagTypePort port | ||||
|             ) | ||||
|         { | ||||
| @@ -45,6 +47,7 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|             this.getAllTagTypesHandler = getAllTagTypesHandler; | ||||
|             this.getTagTypeHandler = getTagTypeHandler; | ||||
|             this.getAllTagTypesByListHandler = getAllTagTypesByListHandler; | ||||
|             this.deleteTagTypeHandler = deleteTagTypeHandler; | ||||
|             this.port = port; | ||||
|         } | ||||
|  | ||||
| @@ -183,5 +186,23 @@ namespace Core.Inventory.Service.API.Controllers | ||||
|  | ||||
|             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> | ||||
|     <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" /> | ||||
|   </ItemGroup> | ||||
|  | ||||
|   | ||||
| @@ -108,6 +108,10 @@ namespace Core.Inventory.Service.API.Extensions | ||||
|             services.AddScoped<IValidator<ChangeTagTypeStatusRequest>, ChangeTagTypeStatusValidator>(); | ||||
|             services.AddScoped<IComponentHandler<ChangeTagTypeStatusRequest>, TagTypeHandler>(); | ||||
|  | ||||
|             services.AddValidatorsFromAssemblyContaining<DeleteTagTypeValidator>(); | ||||
|             services.AddScoped<IValidator<DeleteTagTypeRequest>, DeleteTagTypeValidator>(); | ||||
|             services.AddScoped<IComponentHandler<DeleteTagTypeRequest>, TagTypeHandler>(); | ||||
|  | ||||
|             #endregion | ||||
|  | ||||
|             #region Tag Services | ||||
| @@ -135,6 +139,10 @@ namespace Core.Inventory.Service.API.Extensions | ||||
|             services.AddScoped<IComponentHandler<AddParentTagToTagRequest>, TagHandler>(); | ||||
|             services.AddScoped<IComponentHandler<RemoveParentTagFromTagRequest>, TagHandler>(); | ||||
|  | ||||
|             services.AddValidatorsFromAssemblyContaining<DeleteTagValidator>(); | ||||
|             services.AddScoped<IValidator<DeleteTagRequest>, DeleteTagValidator>(); | ||||
|             services.AddScoped<IComponentHandler<DeleteTagRequest>, TagHandler>(); | ||||
|  | ||||
|             #endregion | ||||
|  | ||||
|             #region TagOverride Services | ||||
| @@ -159,6 +167,10 @@ namespace Core.Inventory.Service.API.Extensions | ||||
|             services.AddScoped<IValidator<ChangeTagOverrideStatusRequest>, ChangeTagOverrideStatusValidator>(); | ||||
|             services.AddScoped<IComponentHandler<ChangeTagOverrideStatusRequest>, TagOverrideHandler>(); | ||||
|  | ||||
|             services.AddValidatorsFromAssemblyContaining<DeleteTagOverrideValidator>(); | ||||
|             services.AddScoped<IValidator<DeleteTagOverrideRequest>, DeleteTagOverrideValidator>(); | ||||
|             services.AddScoped<IComponentHandler<DeleteTagOverrideRequest>, TagOverrideHandler>(); | ||||
|  | ||||
|             #endregion | ||||
|  | ||||
|             #region Product Services | ||||
| @@ -183,6 +195,10 @@ namespace Core.Inventory.Service.API.Extensions | ||||
|             services.AddScoped<IValidator<ChangeProductStatusRequest>, ChangeProductStatusValidator>(); | ||||
|             services.AddScoped<IComponentHandler<ChangeProductStatusRequest>, ProductHandler>(); | ||||
|  | ||||
|             services.AddValidatorsFromAssemblyContaining<DeleteProductValidator>(); | ||||
|             services.AddScoped<IValidator<DeleteProductRequest>, DeleteProductValidator>(); | ||||
|             services.AddScoped<IComponentHandler<DeleteProductRequest>, ProductHandler>(); | ||||
|  | ||||
|             #endregion | ||||
|  | ||||
|             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