CourseWorkElectronicsShop/ElectronicsShop/ElectronicsShopRestAPI/Controllers/MainController.cs
Илья Федотов 48024dbc5e Update / Delete
2024-05-29 21:21:17 +04:00

83 lines
2.3 KiB
C#

using ElectronicsShopContracts.BindingModels;
using ElectronicsShopContracts.BusinessLogicContracts;
using ElectronicsShopContracts.SearchModels;
using ElectronicsShopContracts.ViewModels;
using ElectronicsShopDataBaseImplement.Models;
using Microsoft.AspNetCore.Mvc;
namespace ElectronicsShopRestAPI.Controllers {
[Route("api/[controller]/[action]")]
[ApiController]
public class MainController : Controller {
private readonly ILogger _logger;
private readonly IProductLogic _product;
private readonly IOrderLogic _order;
public MainController(ILogger<MainController> logger, IProductLogic product,
IOrderLogic orderLogic) {
_logger = logger;
_product = product;
_order = orderLogic;
}
[HttpGet]
public List<ProductViewModel>? GetProducts() {
try {
return _product.ReadList(null);
}
catch (Exception ex) {
_logger.LogError(ex, $"Ошибка получения данных");
throw;
}
}
[HttpGet]
public ProductViewModel? GetProduct(int _productID)
{
try
{
return _product.ReadElement(new ProductSearchModel
{
ID = _productID
});
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения товаров id={Id}", _productID);
throw;
}
}
[HttpGet]
public List<OrderViewModel>? GetOrders(int _clientID) {
try
{
return _order.ReadList(new OrderSearchModel
{
ID = _clientID
});
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка заказов клиента id = {Id} ", _clientID);
throw;
}
}
[HttpPost]
public void CreateOrder(OrderBindingModel model) {
try
{
_order.CreateOrder(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания заказа");
throw;
}
}
}
}