using ComputerShopContracts.BindingModels; using ComputerShopContracts.BusinessLogicContracts; using ComputerShopContracts.SearchModels; using ComputerShopContracts.StorageContracts; using ComputerShopContracts.ViewModels; using ComputerShopDataModels.Enums; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ComputerShopBusinessLogic.BusinessLogics { public class OrderLogic : IOrderLogic { private readonly ILogger _logger; //Хранение всех заказов private readonly IOrderStorage _orderStorage; public OrderLogic(ILogger logger, IOrderStorage orderStorage) { _logger = logger; _orderStorage = orderStorage; } public List? ReadList(OrderSearchModel? model) { var list = model == null ? _orderStorage.GetFullList() : _orderStorage.GetFilteredList(model); if (list == null) { _logger.LogWarning("ReadList return null list"); return null; } _logger.LogInformation("ReadList. Count:{Count}", list.Count); return list; } public OrderViewModel? ReadElement(OrderSearchModel model) { if (model == null) { throw new ArgumentNullException(nameof(model)); } var element = _orderStorage.GetElement(model); if (element == null) { _logger.LogWarning("ReadElement order not found"); return null; } _logger.LogInformation("ReadElement order found. Id:{Id}", element.Id); return element; } private void CheckModel(OrderBindingModel model, bool withParams = true) { if (model == null) { throw new ArgumentNullException(nameof(model)); } if (!withParams) { return; } if (model.DateCreate > DateTime.Now) { throw new ArgumentException($"Дата создания заказа {model.DateCreate} не может быть в будущем"); } } public bool Create(OrderBindingModel model) { CheckModel(model); if (model.Status != OrderStatus.Неизвестен) { _logger.LogWarning("Invalid order status"); return false; } model.Status = OrderStatus.Принят; if (_orderStorage.Insert(model) == null) { _logger.LogWarning("Insert operation failed"); return false; } return true; } //!!!ПРОВЕРИТЬ public bool Update(OrderBindingModel model) { CheckModel(model, false); var order = _orderStorage.GetElement(new OrderSearchModel { Id = model.Id }); if (order == null) { throw new ArgumentNullException(nameof(order)); } if (_orderStorage.Update(model) == null) { _logger.LogWarning("Update operation failed"); return false; } //!!!ПРОВЕРИТЬ //if (model.Status != null & ChangeStatus(model, order.Status)) //{ // ordee.DateCreate[model.DateCreate; // return true; //} //model.Status = order.Status; //model.Sum = order.Sum; return true; } public bool Delete(OrderBindingModel model) { CheckModel(model, false); _logger.LogInformation("Delete. Id:{Id}", model.Id); if (_orderStorage.Delete(model) == null) { _logger.LogWarning("Delete order operation failed"); return false; } return true; } //!!!ПРОВЕРИТЬ private bool ChangeStatus(OrderBindingModel model, OrderStatus newStatus) { CheckModel(model, false); var order = _orderStorage.GetElement(new OrderSearchModel { Id = model.Id }); if (order == null) { throw new ArgumentNullException(nameof(order)); } if (newStatus - model.Status == 1) { model.Status = newStatus; if (_orderStorage.Update(model) == null) { _logger.LogWarning("Update order operation failed"); return false; } return true; } if (order.Status + 1 != newStatus) { _logger.LogWarning("Change status operation failed. Incorrect new status: {newStatus}. Current status: {currStatus}", newStatus, order.Status); return false; } _logger.LogWarning("Changing status operation faled: current:{Status}: required:{newStatus}.", model.Status, newStatus); throw new ArgumentException($"Невозможно присвоить статус {newStatus} заказу с текущим статусом {model.Status}"); } //Перевод заказа в состояние выполнения public bool TakeOrderInWork(OrderBindingModel model) { return ChangeStatus(model, OrderStatus.Выполняется); } //Перевод заказа в состояние готовности public bool FinishOrder(OrderBindingModel model) { return ChangeStatus(model, OrderStatus.Готов); } //Перевод заказа в состояние выдачи (окончательное завершение) public bool DeliveryOrder(OrderBindingModel model) { return ChangeStatus(model, OrderStatus.Выдан); } } }