2023-04-09 22:44:20 +04:00
|
|
|
|
using FoodOrdersContracts.BindingModels;
|
|
|
|
|
using FoodOrdersContracts.BusinessLogicsContracts;
|
2023-04-09 23:24:30 +04:00
|
|
|
|
using FoodOrdersContracts.SearchModels;
|
2023-04-09 22:44:20 +04:00
|
|
|
|
using FoodOrdersContracts.ViewModels;
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
using System.Text.Json;
|
|
|
|
|
|
|
|
|
|
namespace FoodOrdersRestApi.Controllers
|
|
|
|
|
{
|
|
|
|
|
[Route("api/[controller]/[action]")]
|
|
|
|
|
[ApiController]
|
|
|
|
|
public class ShopController : Controller
|
|
|
|
|
{
|
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
|
|
|
|
|
private readonly IShopLogic _logic;
|
|
|
|
|
|
|
|
|
|
public ShopController(IShopLogic logic, ILogger<ShopController> logger)
|
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
_logic = logic;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpGet]
|
|
|
|
|
public List<ShopViewModel>? GetShops()
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
return _logic.ReadList(null);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка получения списка магазинов");
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpGet]
|
|
|
|
|
public Tuple<ShopViewModel, IEnumerable<DishViewModel>, IEnumerable<int>>? GetShopWithDishes(int id)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
var shop = _logic.ReadElement(new() { Id = id });
|
|
|
|
|
if (shop == null)
|
|
|
|
|
{
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
return Tuple.Create(shop,
|
|
|
|
|
shop.ShopDishes.Select(x => new DishViewModel()
|
|
|
|
|
{
|
|
|
|
|
Id = x.Value.Item1.Id,
|
|
|
|
|
Price = x.Value.Item1.Price,
|
|
|
|
|
DishName = x.Value.Item1.DishName,
|
|
|
|
|
}),
|
|
|
|
|
shop.ShopDishes.Select(x => x.Value.Item2));
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка получения магазина");
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpPost]
|
|
|
|
|
public void CRUDShop(Action action)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
action.Invoke();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка операции CRUD - {operation} с магазином", action.Method.Name);
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-04-11 16:01:49 +04:00
|
|
|
|
[HttpPost]
|
|
|
|
|
public void CreateShop(ShopBindingModel model)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_logic.Update(model);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка обновления данных");
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-04-09 22:44:20 +04:00
|
|
|
|
|
2023-04-11 16:01:49 +04:00
|
|
|
|
[HttpPost]
|
|
|
|
|
public void DeleteShop(ShopBindingModel model)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_logic.Create(model);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка удаления магазина");
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpPost]
|
|
|
|
|
public void AddDishInShop(Tuple<ShopSearchModel, DishViewModel, int> model)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_logic.DeliveryDishes(model.Item1, model.Item2, model.Item3);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError(ex, "Ошибка добавления суши в магазин");
|
|
|
|
|
throw;
|
|
|
|
|
}
|
2023-04-09 23:24:30 +04:00
|
|
|
|
}
|
2023-04-11 16:01:49 +04:00
|
|
|
|
}
|
2023-04-09 22:44:20 +04:00
|
|
|
|
}
|