2024-06-24 16:04:51 +04:00
|
|
|
|
using BusinessLogic.BusinessLogic;
|
|
|
|
|
using Contracts.BindingModels;
|
|
|
|
|
using Contracts.BusinessLogicContracts;
|
|
|
|
|
using Contracts.Exceptions;
|
|
|
|
|
using Contracts.SearchModels;
|
|
|
|
|
using Contracts.ViewModels;
|
|
|
|
|
using Microsoft.AspNetCore.Http.HttpResults;
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
|
|
|
|
|
namespace RestAPI.Controllers
|
|
|
|
|
{
|
|
|
|
|
[Route("[controller]/[action]")]
|
|
|
|
|
[ApiController]
|
|
|
|
|
public class MainController
|
|
|
|
|
{
|
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
private readonly IProductLogic _product;
|
|
|
|
|
|
|
|
|
|
public MainController(ILogger<MainController> logger, IProductLogic productLogic)
|
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
_product = productLogic;
|
|
|
|
|
}
|
|
|
|
|
[HttpGet]
|
2024-06-24 17:13:06 +04:00
|
|
|
|
public List<ProductViewModel>? GetFullProductList()
|
2024-06-24 16:04:51 +04:00
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
return _product.ReadList(null);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
2024-06-24 17:13:06 +04:00
|
|
|
|
_logger.LogError(ex, "Ошибка получения списка продуктов");
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpGet]
|
|
|
|
|
public List<ProductViewModel>? GetFilteredProductList()
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
return _product.ReadList(null);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка получения списка продуктов");
|
2024-06-24 16:04:51 +04:00
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpPatch]
|
|
|
|
|
public IResult Update([FromBody] ProductBindingModel model)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var res = _product.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 user");
|
|
|
|
|
return Results.Problem(ex.Message);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpDelete]
|
|
|
|
|
public IResult Delete(Guid id)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var res = _product.Delete(new() { Id = id });
|
|
|
|
|
return Results.Ok(res);
|
|
|
|
|
}
|
|
|
|
|
catch (ElementNotFoundException ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogInformation(ex, "User not found");
|
|
|
|
|
return Results.NoContent();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Error delete user");
|
|
|
|
|
return Results.Problem(ex.Message);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|