using ComputerShopContracts.BindingModels;
using ComputerShopContracts.BusinessLogicContracts;
using ComputerShopContracts.SearchModels;
using ComputerShopContracts.ViewModels;
using Microsoft.AspNetCore.Mvc;

namespace ComputerShopRestApi.Controllers
{
	[Route("api/[controller]/[action]")]
	[ApiController]
	public class RequestController : Controller
	{
		private readonly ILogger _logger;

		private readonly IRequestLogic _logic;

		public RequestController(IRequestLogic logic, ILogger<RequestController> logger)
		{
			_logger = logger;
			_logic = logic;
		}


		[HttpGet]
		public RequestViewModel? GetRequest(int id)
		{
			try
			{
				return _logic.ReadElement(new RequestSearchModel
				{
					Id = id
				});
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка получения заказа");
				throw;
			}
		}

		/// <summary>
		/// Получение заявок по id пользователя (полный список, кот. будет выводиться)
		/// </summary>
		/// <param name="userId"></param>
		/// <returns></returns>
		[HttpGet]
		public List<RequestViewModel>? GetRequests(int userId)
		{
			try
			{
				return _logic.ReadList(new RequestSearchModel { UserId = userId });
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка получения списка заказов клиента id={Id}", userId);
				throw;
			}
		}


		[HttpPost]
		public void CreateRequest(RequestBindingModel model)
		{
			try
			{
				_logic.Create(model);
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка создания заказа");
				throw;
			}
		}

		[HttpPost]
		public void ConnectRequestAssembly(RequestBindingModel model)
		{
			try
			{
				_logic.ConnectRequestAssembly(model);
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка связывания заявки со сборкой");
				throw;
			}
		}


		[HttpPost]
		public void UpdateRequest(RequestBindingModel model)
		{
			try
			{
				_logic.Update(model);
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка обновления заказа");
				throw;
			}
		}

		[HttpPost]
		public void DeleteRequest(RequestBindingModel model)
		{
			try
			{
				_logic.Delete(model);
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка удаления заказа");
				throw;
			}
		}
	}
}