PIbd-23-Salin-O.A.-IceCream.../IceCreamShop/IceCreamShopRestApi/Controllers/ShopController.cs
2024-04-14 12:31:53 +04:00

106 lines
2.2 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using IceCreamShopContracts.BindingModels;
using IceCreamShopContracts.BusinessLogicsContracts;
using IceCreamShopContracts.SearchModels;
using IceCreamShopContracts.ViewModels;
using IceCreamShopDataModels.Models;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
namespace IceCreamShopRestApi.Controllers
{
[Route("api/[controller]/[action]")]
[ApiController]
public class ShopController : ControllerBase
{
private readonly ILogger _logger;
private readonly IShopLogic _logic;
public ShopController(IShopLogic logic, ILogger<ShopController>
logger)
{
_logger = logger;
_logic = logic;
}
[HttpGet]
public ShopViewModel GetShop(ShopSearchModel model)
{
try
{
return _logic.ReadElement(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка магазинов");
throw;
}
}
[HttpGet]
public List<ShopViewModel> GetShops()
{
try
{
return _logic.ReadList(null);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка магазинов");
throw;
}
}
[HttpPost]
public bool CreateShop(ShopBindingModel model)
{
try
{
return _logic.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Не удалось создать магазин");
throw;
}
}
[HttpPost]
public bool UpdateShop(ShopBindingModel model)
{
try
{
return _logic.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Не удалось обновить магазин");
throw;
}
}
[HttpPost]
public bool DeleteShop(ShopBindingModel model)
{
try
{
return _logic.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Не удалось удалить магазин");
throw;
}
}
[HttpPost]
public bool MakeSupply(ShopSearchModel model, IIceCreamModel iceCream, int count)
{
try
{
return _logic.MakeSupply(model, iceCream, count);
}
catch (Exception ex)
{
_logger.LogError(ex, "Не удалось сделать поставку в магазин");
throw;
}
}
}
}