using ComputerShopContracts.BindingModels; using ComputerShopContracts.BusinessLogicContracts; using ComputerShopContracts.SearchModels; using ComputerShopContracts.StorageContracts; using ComputerShopContracts.ViewModels; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using System.Reflection; namespace ComputerShopRestApi.Controllers { [Route("api/[controller]/[action]")] [ApiController] public class OrderController : Controller { private readonly ILogger _logger; private readonly IOrderLogic _order; private readonly IOrderStorage _orderStorage; public OrderController(ILogger logger, IOrderLogic order, ISupplyLogic supply) { _logger = logger; _order = order; } [HttpGet] public List? GetOrderList(int clientId) { try { return _order.ReadList(new OrderSearchModel { ClientId = clientId }); } catch (Exception ex) { _logger.LogError(ex, "Ошибка получения списка заказов"); throw; } } [HttpGet] public List? GetOrders(int clientId) { try { return _order.ReadList(new OrderSearchModel {}); } 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; } } [HttpDelete] public void DeleteOrder(OrderBindingModel model) { try { _order.Delete(model); } catch (Exception ex) { _logger.LogError(ex, "Ошибка при удалении заказа"); throw; } } [HttpPost] public void FinishOrder(int id) { try { var order = _orderStorage.GetElement(new() { Id = id }); OrderBindingModel model = new OrderBindingModel() { Id = id, ClientId = order.ClientId, DateImplement = order.DateImplement, Status = order.Status }; _order.FinishOrder(model); } catch (Exception ex) { _logger.LogError(ex, "Ошибка изменения закупки"); throw; } } [HttpPost] public void DeliveryOrder(int id) { try { var order = _orderStorage.GetElement(new() { Id = id }); OrderBindingModel model = new OrderBindingModel() { Id = id, ClientId = order.ClientId, DateImplement = order.DateImplement, Status = order.Status }; _order.DeliveryOrder(model); } catch (Exception ex) { _logger.LogError(ex, "Ошибка изменения закупки"); throw; } } [HttpPost] public void TakeOrderInWork(int id) { try { var order = _orderStorage.GetElement(new() { Id = id }); OrderBindingModel model = new OrderBindingModel() { Id = id, ClientId = order.ClientId, DateImplement = order.DateImplement, Status = order.Status }; _order.TakeOrderInWork(model); } catch (Exception ex) { _logger.LogError(ex, "Ошибка изменения закупки"); throw; } } [HttpPost] public void AddAssembly(Tuple model) { try { _order.AddAssembly(model.Item1, model.Item2, model.Item3); } catch (Exception ex) { _logger.LogError(ex, "Ошибка добавления компонента в сборку."); throw; } } } }