using Ardalis.ApiEndpoints; using Microsoft.AspNetCore.Authentication.JwtBearer; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.eShopWeb.ApplicationCore.Entities; using Microsoft.eShopWeb.ApplicationCore.Interfaces; using Swashbuckle.AspNetCore.Annotations; using System.IO; using System.Threading; using System.Threading.Tasks; namespace Microsoft.eShopWeb.PublicApi.CatalogItemEndpoints { [Authorize(Roles = BlazorShared.Authorization.Constants.Roles.ADMINISTRATORS, AuthenticationSchemes = JwtBearerDefaults.AuthenticationScheme)] public class Create : BaseAsyncEndpoint .WithRequest .WithResponse { private readonly IAsyncRepository _itemRepository; private readonly IUriComposer _uriComposer; public Create(IAsyncRepository itemRepository, IUriComposer uriComposer) { _itemRepository = itemRepository; _uriComposer = uriComposer; } [HttpPost("api/catalog-items")] [SwaggerOperation( Summary = "Creates a new Catalog Item", Description = "Creates a new Catalog Item", OperationId = "catalog-items.create", Tags = new[] { "CatalogItemEndpoints" }) ] public override async Task> HandleAsync(CreateCatalogItemRequest request, CancellationToken cancellationToken) { var response = new CreateCatalogItemResponse(request.CorrelationId()); var newItem = new CatalogItem(request.CatalogTypeId, request.CatalogBrandId, request.Description, request.Name, request.Price, request.PictureUri); newItem = await _itemRepository.AddAsync(newItem, cancellationToken); if (newItem.Id != 0) { // At this point time, the Admin application uses the default catalog item image for any new product item. // But in the actual production scenario, you'll implement the image file upload mechanism in your application and set the image // file the Uri accordingly. You can refer to fewlines of the boilerplate code are commented out and kept it in the following files. // - BlazorAdmin project -> Create.razor and Edit.razor. // - Infrastructure project -> Services/WebFileSystem.cs newItem.UpdatePictureUri("eCatalog-item-default.png"); await _itemRepository.UpdateAsync(newItem, cancellationToken); } var dto = new CatalogItemDto { Id = newItem.Id, CatalogBrandId = newItem.CatalogBrandId, CatalogTypeId = newItem.CatalogTypeId, Description = newItem.Description, Name = newItem.Name, PictureUri = _uriComposer.ComposePicUri(newItem.PictureUri), Price = newItem.Price }; response.CatalogItem = dto; return response; } } }