using AbstractFoodOrdersContracts.BindingModels;
using AbstractFoodOrdersContracts.BusinessLogicsContracts;
using AbstractFoodOrdersContracts.SearchModels;
using AbstractFoodOrdersContracts.ViewModels;
using Microsoft.AspNetCore.Mvc;

namespace AbstractFoodOrdersRestApi.Controllers
{
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class ClientController : Controller
    {
        private readonly ILogger _logger;
        private readonly IClientLogic _logic;
		private readonly IMessageInfoLogic _mailLogic;
		public ClientController(IClientLogic logic, IMessageInfoLogic mailLogic, ILogger<ClientController>
       logger)
        {
            _logger = logger;
            _logic = logic;
            _mailLogic = mailLogic;
        }
        [HttpGet]
        public ClientViewModel? Login(string login, string password)
        {
            try
            {
                return _logic.ReadElement(new ClientSearchModel
                {
                    Email = login,
                    Password = password
                });
            }
            catch (Exception ex)
            {
                _logger.LogError(ex, "Ошибка входа в систему");
                throw;
            }
        }
        [HttpPost]
        public void Register(ClientBindingModel model)
        {
            try
            {
                _logic.Create(model);
            }
            catch (Exception ex)
            {
                _logger.LogError(ex, "Ошибка регистрации");
                throw;
            }
        }
        [HttpPost]
        public void UpdateData(ClientBindingModel 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;
			}
		}

	}
}