using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Authorization; using DomainResults.Mvc; using WeatherForecast.Services; using WeatherForecast.Models.Requests; using WeatherForecast.Policies; using Core.Enumerations; namespace WeatherForecast.Controllers; /// /// /// [ApiController] [Route("api/[controller]")] public class ShopItemController : ControllerBase { private readonly IAuthorizationService _authorizationService; private readonly IShopItemService _shopItemService; private readonly WebapiControllers _webapiController = WebapiControllers.ShopItem; /// /// /// /// public ShopItemController( IAuthorizationService authorizationService, IShopItemService shopItemService ) { _authorizationService = authorizationService; _shopItemService = shopItemService; } /// /// /// /// /// /// /// [HttpPost("{siteId}/{sku}")] public async Task Post([FromRoute] Guid siteId, [FromRoute] string sku, [FromBody] ShopItemRequestModel requestData) { if ((await _authorizationService.AuthorizeAsync(User, null, new CrudActionRequirement(_webapiController, CrudActions.Create))).Succeeded) { var result = _shopItemService.Post(siteId, sku, requestData); return result.ToActionResult(); } return Unauthorized(); } /// /// Returns full object /// /// /// /// [HttpGet("{siteId}/{sku}")] public async Task Get([FromRoute] Guid siteId, [FromRoute] string sku) { if ((await _authorizationService.AuthorizeAsync(User, null, new CrudActionRequirement(_webapiController, CrudActions.Read))).Succeeded) { var result = _shopItemService.Get(siteId, sku); return result.ToActionResult(); } return Unauthorized(); } /// /// /// /// /// /// [HttpGet("{siteId}")] public IActionResult GetSlug([FromRoute] Guid siteId, [FromQuery] string slug) { var result = _shopItemService.GetSlug(siteId, slug); return result.ToActionResult(); } /// /// /// /// /// /// /// [HttpPut("{siteId}/{sku}")] public async Task Update([FromRoute] Guid siteId, [FromRoute] string sku, [FromBody] ShopItemRequestModel requestData) { if ((await _authorizationService.AuthorizeAsync(User, null, new CrudActionRequirement(_webapiController, CrudActions.Update))).Succeeded) { var result = _shopItemService.Update(siteId, sku, requestData); return result.ToActionResult(); } return Unauthorized(); } /// /// /// /// /// /// [HttpDelete("{siteId}/{sku}")] public async Task Delete([FromRoute] Guid siteId, [FromRoute] string sku) { if ((await _authorizationService.AuthorizeAsync(User, null, new CrudActionRequirement(_webapiController, CrudActions.Delete))).Succeeded) { var result = _shopItemService.Delete(siteId, sku); return result.ToActionResult(); } return Unauthorized(); } }