108 lines
2.8 KiB
C#
108 lines
2.8 KiB
C#
|
using SushiBarContracts.BindingModels;
|
|||
|
using SushiBarContracts.BusinessLogicsContracts;
|
|||
|
using SushiBarContracts.SearchModels;
|
|||
|
using SushiBarContracts.ViewModels;
|
|||
|
using Microsoft.AspNetCore.Mvc;
|
|||
|
using SushiBarDataModels.Models;
|
|||
|
|
|||
|
namespace SushiBarRestApi.Controllers
|
|||
|
{
|
|||
|
[Route("api/[controller]/[action]")]
|
|||
|
[ApiController]
|
|||
|
public class ShopCOntroller : Controller
|
|||
|
{
|
|||
|
private readonly ILogger _logger;
|
|||
|
|
|||
|
private readonly IShopLogic _shop;
|
|||
|
|
|||
|
public ShopCOntroller(ILogger<MainController> logger, IShopLogic shop)
|
|||
|
{
|
|||
|
_logger = logger;
|
|||
|
_shop = shop;
|
|||
|
}
|
|||
|
|
|||
|
[HttpGet]
|
|||
|
public List<ShopViewModel>? GetShops()
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
return _shop.ReadList(null);
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка получения списка магазинов");
|
|||
|
throw;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[HttpGet]
|
|||
|
public ShopViewModel? GetShop(int shopId)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
return _shop.ReadElement(new ShopSearchModel { Id = shopId });
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка получения магазина по id={Id}", shopId);
|
|||
|
throw;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[HttpPost]
|
|||
|
public void CreateShop(ShopBindingModel model)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
_shop.Create(model);
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка создания магазина");
|
|||
|
throw;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[HttpPost]
|
|||
|
public void UpdateData(ShopBindingModel model)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
_shop.Update(model);
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка обновления данных");
|
|||
|
throw;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[HttpPost]
|
|||
|
public void DeleteShop(ShopBindingModel model)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
_shop.Delete(model);
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка удаления магазина");
|
|||
|
throw;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[HttpPost]
|
|||
|
public void AddSushiInShop(Tuple<ShopSearchModel, ISushiModel, int> model)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
_shop.AddSushiInShop(model.Item1, model.Item2, model.Item3);
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка добавления суши в магазин");
|
|||
|
throw;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|