Add TagType CRUD #1
							
								
								
									
										154
									
								
								Core.Inventory.DAL.API/Controllers/TagTypeController.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								Core.Inventory.DAL.API/Controllers/TagTypeController.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,154 @@ | ||||
| using Asp.Versioning; | ||||
| using Core.Adapters.Lib; | ||||
| using Core.Blueprint.Logging; | ||||
| using Core.Blueprint.Mongo; | ||||
| using Core.Inventory.Domain.Contexts.Inventory.Request; | ||||
| using Core.Inventory.Provider.Contracts; | ||||
| using Microsoft.AspNetCore.Authorization; | ||||
| using Microsoft.AspNetCore.Mvc; | ||||
|  | ||||
| namespace Core.Inventory.DAL.API.Controllers | ||||
| { | ||||
|     /// <summary> | ||||
|     /// Handles all requests for TagType authentication. | ||||
|     /// </summary> | ||||
|     [ApiVersion(MimeTypes.ApplicationVersion)] | ||||
|     [Route("api/v{api-version:apiVersion}/[controller]")] | ||||
|     [Produces(MimeTypes.ApplicationJson)] | ||||
|     [Consumes(MimeTypes.ApplicationJson)] | ||||
|     [ApiController] | ||||
|     [AllowAnonymous] | ||||
|     public class TagTypeController(ITagTypeProvider service) : ControllerBase | ||||
|     { | ||||
|         /// <summary> | ||||
|         /// Gets all the TagTypes. | ||||
|         /// </summary> | ||||
|         /// <returns>The <see cref="IEnumerable{TagTypeAdapter}"/> found entities.</returns> | ||||
|         /// <response code="200">The tagTypes found.</response> | ||||
|         /// <response code="404">The tagTypes not found error.</response> | ||||
|         /// <response code="500">The service internal error.</response> | ||||
|         [HttpGet] | ||||
|         [Consumes(MimeTypes.ApplicationJson)] | ||||
|         [Produces(MimeTypes.ApplicationJson)] | ||||
|         [ProducesResponseType(typeof(IEnumerable<TagTypeAdapter>), StatusCodes.Status200OK)] | ||||
|         public async Task<IActionResult> GetAllTagTypesAsync(CancellationToken cancellationToken) | ||||
|         { | ||||
|             var result = await service.GetAllTagTypes(cancellationToken).ConfigureAwait(false); | ||||
|             return Ok(result); | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets all the TagTypes by TagType identifiers. | ||||
|         /// </summary> | ||||
|         /// <param name="TagTypes">The list of TagType identifiers.</param> | ||||
|         /// <returns>The <see cref="IEnumerable{TagTypeAdapter}"/> found entities.</returns> | ||||
|         /// <response code="200">The TagTypes found.</response> | ||||
|         /// <response code="404">The TagTypes not found error.</response> | ||||
|         /// <response code="500">The service internal error.</response> | ||||
|         [HttpPost] | ||||
|         [Route("GetTagTypeList")] | ||||
|         [Consumes(MimeTypes.ApplicationJson)] | ||||
|         [Produces(MimeTypes.ApplicationJson)] | ||||
|         [ProducesResponseType(typeof(IEnumerable<TagTypeAdapter>), StatusCodes.Status200OK)] | ||||
|         public async Task<IActionResult> GetAllTagTypesByList([FromBody] string[] tagTypes, CancellationToken cancellationToken) | ||||
|         { | ||||
|             if (tagTypes == null || !tagTypes.Any()) | ||||
|             { | ||||
|                 return BadRequest("TagType identifiers are required."); | ||||
|             } | ||||
|  | ||||
|             var result = await service.GetAllTagTypesByList(tagTypes, cancellationToken).ConfigureAwait(false); | ||||
|             return Ok(result); | ||||
|         } | ||||
|  | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets the TagType by identifier. | ||||
|         /// </summary> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <returns>The <see cref="TagTypeAdapter"/> found entity.</returns> | ||||
|         /// <response code="200">The TagType found.</response> | ||||
|         /// <response code="404">The TagType not found error.</response> | ||||
|         /// <response code="500">The service internal error.</response> | ||||
|         [HttpGet] | ||||
|         [Route("{id}")] | ||||
|         [Consumes(MimeTypes.ApplicationJson)] | ||||
|         [Produces(MimeTypes.ApplicationJson)] | ||||
|         [ProducesResponseType(typeof(TagTypeAdapter), StatusCodes.Status200OK)] | ||||
|         public async Task<IActionResult> GetTagTypeByIdAsync([FromRoute] string id, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var result = await service.GetTagTypeById(id, cancellationToken).ConfigureAwait(false); | ||||
|  | ||||
|             if (result == null) | ||||
|             { | ||||
|                 return NotFound("Entity not found"); | ||||
|             } | ||||
|  | ||||
|             return Ok(result); | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Creates a new TagType. | ||||
|         /// </summary> | ||||
|         /// <param name="newTagType">The TagType to be added.</param> | ||||
|         /// <returns>The <see cref="TagTypeAdapter"/> created entity.</returns> | ||||
|         /// <response code="201">The TagType created.</response> | ||||
|         /// <response code="422">The TagType could not be created.</response> | ||||
|         /// <response code="500">The service internal e|ror.</response> | ||||
|         [HttpPost] | ||||
|         [ProducesResponseType(typeof(TagTypeAdapter), StatusCodes.Status201Created)] | ||||
|         public async Task<IActionResult> CreateTagTypeAsync([FromBody] TagTypeRequest newTagType, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var result = await service.CreateTagType(newTagType, cancellationToken).ConfigureAwait(false); | ||||
|             return Created("CreatedWithIdAsync", result); | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Updates a full TagType by identifier. | ||||
|         /// </summary> | ||||
|         /// <param name="entity">The TagType to update.</param> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <returns>The <see cref="TagTypeAdapter"/> updated entity.</returns> | ||||
|         /// <response code="200">The TagType updated.</response> | ||||
|         /// <response code="404">The TagType not found.</response> | ||||
|         /// <response code="422">The TagType could not be updated.</response> | ||||
|         /// <response code="500">The service internal error.</response> | ||||
|         [HttpPut] | ||||
|         [Route("{id}")] | ||||
|         [Consumes(MimeTypes.ApplicationJson)] | ||||
|         [Produces(MimeTypes.ApplicationJson)] | ||||
|         [ProducesResponseType(typeof(TagTypeAdapter), StatusCodes.Status200OK)] | ||||
|         public async Task<IActionResult> UpdateTagTypeAsync([FromRoute] string id, TagTypeAdapter entity, CancellationToken cancellationToken) | ||||
|         { | ||||
|             if (id != entity.Id?.ToString()) | ||||
|             { | ||||
|                 return BadRequest("TagType ID mismatch"); | ||||
|             } | ||||
|  | ||||
|             var result = await service.UpdateTagType(entity, cancellationToken).ConfigureAwait(false); | ||||
|  | ||||
|             return Ok(result); | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Changes the status of the TagType. | ||||
|         /// </summary> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <param name="newStatus">The new status of the TagType.</param> | ||||
|         /// <returns>The <see cref="TagTypeAdapter"/> updated entity.</returns> | ||||
|         /// <response code="200">The TagType updates.</response> | ||||
|         /// <response code="404">The TagType not found.</response> | ||||
|         /// <response code="422">The TagType could not be deleted.</response> | ||||
|         /// <response code="500">The service internal error.</response> | ||||
|         [HttpPatch] | ||||
|         [Route("{id}/{newStatus}/ChangeStatus")] | ||||
|         [Consumes(MimeTypes.ApplicationJson)] | ||||
|         [Produces(MimeTypes.ApplicationJson)] | ||||
|         [ProducesResponseType(typeof(TagTypeAdapter), StatusCodes.Status200OK)] | ||||
|         public async Task<IActionResult> ChangeTagTypeStatus([FromRoute] string id, [FromRoute] StatusEnum newStatus, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var result = await service.ChangeTagTypeStatus(id, newStatus, cancellationToken).ConfigureAwait(false); | ||||
|             return Ok(result); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,44 @@ | ||||
| using MongoDB.Bson; | ||||
| using MongoDB.Bson.Serialization.Attributes; | ||||
| using System.Text.Json.Serialization; | ||||
|  | ||||
| namespace Core.Inventory.Domain.Contexts.Inventory.Request | ||||
| { | ||||
|     /// <summary> | ||||
|     /// Data transfer object (DTO) for adding tagType. | ||||
|     /// </summary> | ||||
|     public class TagTypeRequest | ||||
|     { | ||||
|         /// <summary> | ||||
|         /// Gets or sets the tenantId of the tagType. | ||||
|         /// </summary> | ||||
|         [BsonElement("tenantId")] | ||||
|         [BsonRepresentation(BsonType.String)] | ||||
|         [JsonPropertyName("tenantId")] | ||||
|         public string TenantId { get; set; } = null!; | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets or sets the typeName of the tagType. | ||||
|         /// </summary> | ||||
|         [BsonElement("typeName")] | ||||
|         [BsonRepresentation(BsonType.String)] | ||||
|         [JsonPropertyName("typeName")] | ||||
|         public string TypeName { get; set; } = null!; | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets or sets the level of the tagType. | ||||
|         /// </summary> | ||||
|         [BsonElement("level")] | ||||
|         [BsonRepresentation(BsonType.Int32)] | ||||
|         [JsonPropertyName("level")] | ||||
|         public int Level { get; set; } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets or sets the parentTypeId of the tagType. | ||||
|         /// </summary> | ||||
|         [BsonElement("parentTypeId")] | ||||
|         [BsonRepresentation(BsonType.String)] | ||||
|         [JsonPropertyName("parentTypeId")] | ||||
|         public string ParentTypeId { get; set; } = null!; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										59
									
								
								Core.Inventory.Provider/Contracts/ITagTypeProvider.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								Core.Inventory.Provider/Contracts/ITagTypeProvider.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| using Core.Adapters.Lib; | ||||
| using Core.Blueprint.Mongo; | ||||
| using Core.Inventory.Domain.Contexts.Inventory.Request; | ||||
|  | ||||
| namespace Core.Inventory.Provider.Contracts | ||||
| { | ||||
|     public interface ITagTypeProvider | ||||
|     { | ||||
|         /// <summary> | ||||
|         /// Creates a new TagType. | ||||
|         /// </summary> | ||||
|         /// <param name="entity">The TagType to be created.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         ValueTask<TagTypeAdapter> CreateTagType(TagTypeRequest newTagType, CancellationToken cancellationToken); | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets an TagType by identifier. | ||||
|         /// </summary> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         ValueTask<TagTypeAdapter> GetTagTypeById(string _id, CancellationToken cancellationToken); | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets all the tagTypes. | ||||
|         /// </summary> | ||||
|         /// <returns>A <see cref="{Task{IEnumerbale{TagTypeAdapter}}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         ValueTask<IEnumerable<TagTypeAdapter>> GetAllTagTypes(CancellationToken cancellationToken); | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets all the tagTypes by tagTypes identifier list. | ||||
|         /// </summary> | ||||
|         /// <param name="tagTypes">The list of tagTypes identifiers.</param> | ||||
|         /// <returns>A <see cref="Task{IEnumerable{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         ValueTask<IEnumerable<TagTypeAdapter>> GetAllTagTypesByList(string[] TagTypes, CancellationToken cancellationToken); | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Changes the status of the tagType. | ||||
|         /// </summary> | ||||
|         /// <param name="id">The tagType identifier.</param> | ||||
|         /// <param name="newStatus">The new status of the tagType.</param> | ||||
|         /// <returns>The <see cref="TagTypeAdapter"/> updated entity.</returns> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         ValueTask<TagTypeAdapter> ChangeTagTypeStatus(string id, StatusEnum newStatus, CancellationToken cancellationToken); | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Updates a TagType by id. | ||||
|         /// </summary> | ||||
|         /// <param name="entity">The TagType to be updated.</param> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         ValueTask<TagTypeAdapter> UpdateTagType(TagTypeAdapter entity, CancellationToken cancellationToken); | ||||
|     } | ||||
| } | ||||
| @@ -7,7 +7,7 @@ | ||||
|   </PropertyGroup> | ||||
|  | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="Adapters.Lib" Version="1.0.8" /> | ||||
|     <PackageReference Include="Adapters.Lib" Version="1.0.9" /> | ||||
|     <PackageReference Include="Core.Blueprint.Mongo" Version="1.0.0" /> | ||||
|     <PackageReference Include="Core.Blueprint.Redis" Version="1.0.2" /> | ||||
|     <PackageReference Include="Mapster" Version="7.4.0" /> | ||||
|   | ||||
							
								
								
									
										149
									
								
								Core.Inventory.Provider/Providers/Inventory/TagTypeProvider.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								Core.Inventory.Provider/Providers/Inventory/TagTypeProvider.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,149 @@ | ||||
| using Core.Adapters.Lib; | ||||
| using Core.Blueprint.Mongo; | ||||
| using Core.Blueprint.Redis; | ||||
| using Core.Blueprint.Redis.Helpers; | ||||
| using Core.Inventory.Domain.Contexts.Inventory.Request; | ||||
| using Core.Inventory.Provider.Contracts; | ||||
| using Mapster; | ||||
| using Microsoft.Extensions.Options; | ||||
| using MongoDB.Driver; | ||||
|  | ||||
| namespace Core.Inventory.Provider.Providers.Inventory | ||||
| { | ||||
|     /// <summary> | ||||
|     /// Handles all services and business rules related to <see cref="TagTypeAdapter"/>. | ||||
|     /// </summary> | ||||
|     public class TagTypeProvider : ITagTypeProvider | ||||
|     { | ||||
|         private readonly CollectionRepository<TagTypeAdapter> repository; | ||||
|         private readonly CacheSettings cacheSettings; | ||||
|         private readonly IRedisCacheProvider cacheProvider; | ||||
|  | ||||
|         public TagTypeProvider(CollectionRepository<TagTypeAdapter> repository, | ||||
|             IRedisCacheProvider cacheProvider, | ||||
|             IOptions<CacheSettings> cacheSettings) | ||||
|         { | ||||
|             this.repository = repository; | ||||
|             this.repository.CollectionInitialization(); | ||||
|             this.cacheSettings = cacheSettings.Value; | ||||
|             this.cacheProvider = cacheProvider; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Creates a new TagType. | ||||
|         /// </summary> | ||||
|         /// <param name="entity">The TagType to be created.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         public async ValueTask<TagTypeAdapter> CreateTagType(TagTypeRequest newTagType, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var tagTypeCollection = newTagType.Adapt<TagTypeAdapter>(); | ||||
|  | ||||
|             await repository.InsertOneAsync(tagTypeCollection); | ||||
|  | ||||
|             return tagTypeCollection; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets an TagType by identifier. | ||||
|         /// </summary> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns>0 | ||||
|         public async ValueTask<TagTypeAdapter> GetTagTypeById(string _id, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var cacheKey = CacheKeyHelper.GenerateCacheKey(this, "GetTagTypeById", _id); | ||||
|             var cachedData = await cacheProvider.GetAsync<TagTypeAdapter>(cacheKey); | ||||
|  | ||||
|             if (cachedData is not null) { return cachedData; } | ||||
|  | ||||
|             var tagType = await repository.FindByIdAsync(_id); | ||||
|  | ||||
|             await cacheProvider.SetAsync(cacheKey, tagType); | ||||
|  | ||||
|             return tagType; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets all the TagTypes. | ||||
|         /// </summary> | ||||
|         /// <returns>A <see cref="{Task{IEnumerbale{TagTypeAdapter}}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         public async ValueTask<IEnumerable<TagTypeAdapter>> GetAllTagTypes(CancellationToken cancellationToken) | ||||
|         { | ||||
|             var cacheKey = CacheKeyHelper.GenerateCacheKey(this, "GetTagTypes"); | ||||
|             var cachedData = await cacheProvider.GetAsync<IEnumerable<TagTypeAdapter>>(cacheKey) ?? []; | ||||
|  | ||||
|             if (cachedData.Any()) return cachedData; | ||||
|  | ||||
|             var tagTypes = await repository.AsQueryable(); | ||||
|  | ||||
|             await cacheProvider.SetAsync(cacheKey, tagTypes); | ||||
|  | ||||
|             return tagTypes; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Gets all the TagTypes by TagTypes identifier list. | ||||
|         /// </summary> | ||||
|         /// <param name="TagTypes">The list of TagTypes identifiers.</param> | ||||
|         /// <returns>A <see cref="Task{IEnumerable{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         public async ValueTask<IEnumerable<TagTypeAdapter>> GetAllTagTypesByList(string[] tagTypes, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var cacheKey = CacheKeyHelper.GenerateCacheKey(this, "GetAllTagTypesByList", tagTypes); | ||||
|  | ||||
|             var cachedData = await cacheProvider.GetAsync<IEnumerable<TagTypeAdapter>>(cacheKey) ?? []; | ||||
|  | ||||
|             if (cachedData.Any()) return cachedData; | ||||
|  | ||||
|             var builder = Builders<TagTypeAdapter>.Filter; | ||||
|             var filters = new List<FilterDefinition<TagTypeAdapter>>(); | ||||
|  | ||||
|             if (tagTypes != null || !tagTypes.Any()) | ||||
|             { | ||||
|                 filters.Add(builder.In(x => x._Id, tagTypes)); | ||||
|             } | ||||
|  | ||||
|             var finalFilter = filters.Any() ? builder.And(filters) : builder.Empty; | ||||
|  | ||||
|             var tagTypesList = await repository.FilterByMongoFilterAsync(finalFilter); | ||||
|  | ||||
|             await cacheProvider.SetAsync(cacheKey, tagTypesList); | ||||
|  | ||||
|             return tagTypesList; | ||||
|         } | ||||
|  | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Changes the status of the TagType. | ||||
|         /// </summary> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <param name="newStatus">The new status of the TagType.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         public async ValueTask<TagTypeAdapter> ChangeTagTypeStatus(string id, StatusEnum newStatus, CancellationToken cancellationToken) | ||||
|         { | ||||
|             var entity = await repository.FindByIdAsync(id); | ||||
|             entity.Status = newStatus; | ||||
|  | ||||
|             await repository.ReplaceOneAsync(entity); | ||||
|  | ||||
|             return entity; | ||||
|         } | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Updates a TagType by id. | ||||
|         /// </summary> | ||||
|         /// <param name="entity">The TagType to be updated.</param> | ||||
|         /// <param name="id">The TagType identifier.</param> | ||||
|         /// <returns>A <see cref="{Task{TagTypeAdapter}}"/> representing | ||||
|         /// the asynchronous execution of the service.</returns> | ||||
|         public async ValueTask<TagTypeAdapter> UpdateTagType(TagTypeAdapter entity, CancellationToken cancellationToken) | ||||
|         { | ||||
|             await repository.ReplaceOneAsync(entity); | ||||
|  | ||||
|             return entity; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -17,6 +17,9 @@ namespace Core.Inventory.Provider | ||||
|             services.AddScoped<IFurnitureVariantProvider, FurnitureVariantProvider>(); | ||||
|             services.AddScoped<CollectionRepository<FurnitureVariant>>(); | ||||
|  | ||||
|             services.AddScoped<ITagTypeProvider, TagTypeProvider>(); | ||||
|             services.AddScoped<CollectionRepository<TagTypeAdapter>>(); | ||||
|  | ||||
|             return services; | ||||
|  | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user