PIAPS_CW/RestAPI/Controllers/CartItemController.cs

148 lines
4.6 KiB
C#

using BusinessLogic.BusinessLogic;
using Contracts.BindingModels;
using Contracts.BusinessLogicContracts;
using Contracts.Exceptions;
using Contracts.SearchModels;
using Contracts.ViewModels;
using Microsoft.AspNetCore.Mvc;
namespace RestAPI.Controllers
{
[Route("[controller]/[action]")]
[ApiController]
public class CartItemController : Controller
{
private readonly ICartItemLogic _cartItemLogic;
private readonly IProductLogic _productLogic;
private readonly ILogger _logger;
public CartItemController(ILogger<CartItemController> logger, ICartItemLogic cartItemLogic, IProductLogic productLogic)
{
_logger = logger;
_cartItemLogic = cartItemLogic;
_productLogic = productLogic;
}
[HttpGet]
public List<CartItemViewModel> GetFullList(Guid userId)
{
try
{
return _cartItemLogic.ReadElements(new CartItemSearchModel(){ UserId = userId });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка");
throw;
}
}
[HttpGet]
public CartItemViewModel GetElement(Guid id)
{
try
{
return _cartItemLogic.ReadElement(new CartItemSearchModel() { Id = id });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения элемента корзины");
throw;
}
}
[HttpGet]
public ProductViewModel GetProduct(Guid cartItemId)
{
try
{
var item = _cartItemLogic.ReadElement(new CartItemSearchModel() { Id = cartItemId });
return _productLogic.ReadElement(new ProductSearchModel() { Id = item.ProductId });
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения продукта");
throw;
}
}
[HttpPost]
public IResult Create([FromBody] CartItemBindingModel model)
{
try
{
var res = _cartItemLogic.Create(model);
return Results.Ok(res);
}
catch (AccountException ex)
{
_logger.LogWarning(ex, "Wrong data");
return Results.BadRequest(ex.Message);
}
catch (Exception ex)
{
_logger.LogError(ex, "Error create item");
return Results.Problem(ex.Message);
}
}
[HttpPatch]
public IResult Update([FromBody] CartItemBindingModel model)
{
try
{
var res = _cartItemLogic.Update(model);
return Results.Ok(res);
}
catch (AccountException ex)
{
_logger.LogWarning(ex, "Wrong update data");
return Results.BadRequest(ex.Message);
}
catch (Exception ex)
{
_logger.LogError(ex, "Error update cart item");
return Results.Problem(ex.Message);
}
}
[HttpDelete]
public IResult Delete(Guid id)
{
try
{
var res = _cartItemLogic.Delete(new() { Id = id });
return Results.Ok(res);
}
catch (ElementNotFoundException ex)
{
_logger.LogInformation(ex, "Item not found");
return Results.NoContent();
}
catch (Exception ex)
{
_logger.LogError(ex, "Error delete item");
return Results.Problem(ex.Message);
}
}
[HttpDelete]
public IResult DeleteAll()
{
try
{
var list = _cartItemLogic.ReadElements(null);
var res = new List<IResult>();
foreach (var element in list)
{
_cartItemLogic.Delete(new() { Id = element.Id });
}
return Results.Ok(res);
}
catch (ElementNotFoundException ex)
{
_logger.LogInformation(ex, "Item not found");
return Results.NoContent();
}
catch (Exception ex)
{
_logger.LogError(ex, "Error delete item");
return Results.Problem(ex.Message);
}
}
}
}