using Microsoft.AspNetCore.Mvc;
using ComputerHardwareStoreContracts.BindingModels;
using ComputerHardwareStoreContracts.SearchModels;
using ComputerHardwareStoreContracts.StorageContracts;
using ComputerHardwareStoreContracts.BusinessLogicsContracts;
using ComputerHardwareStoreContracts.ViewModels;

namespace ComputerHardwareStoreREST.Controllers
{
	[Route("api/[controller]/[action]")]
	[ApiController]
    public class StoreKeeperController : Controller
    {
		private readonly ILogger _logger;
		private readonly IStoreKeeperLogic _logic;
		private readonly IMessageInfoLogic _mailLogic;
		public StoreKeeperController(IStoreKeeperLogic logic, IMessageInfoLogic mailLogic, ILogger<StoreKeeperController> logger)
		{
			_logger = logger;
			_logic = logic;
			_mailLogic = mailLogic;
		}
		[HttpGet]
		public StoreKeeperViewModel? Login(string login, string password)
		{
			try
			{
				return _logic.ReadElement(new StoreKeeperSearchModel
				{
					Login = login,
					Password = password
				});
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка входа в систему");
				throw;
			}
		}
		[HttpPost]
		public void Register(StoreKeeperBindingModel model)
		{
			try
			{
				_logic.Create(model);
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка регистрации");
				throw;
			}
		}
		[HttpPost]
		public void UpdateData(StoreKeeperBindingModel model)
		{
			try
			{
				_logic.Update(model);
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка обновления данных");
				throw;
			}
		}
		[HttpGet]
		public List<MessageInfoViewModel>? GetMessages(int clientId)
		{
			try
			{
				return _mailLogic.ReadList(new MessageInfoSearchModel
				{
					ClientId = clientId
				});
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "Ошибка получения писем клиента");
				throw;
			}
		}
	}
}