using SecuritySystemContracts.BindingModels; using SecuritySystemContracts.BusinessLogicsContracts; using SecuritySystemContracts.SearchModels; using SecuritySystemContracts.ViewModels; using Microsoft.AspNetCore.Mvc; namespace SecuritySystemRestApi.Controllers { //указание у контроллера, что Route будет строиться не только по наванию контроллера, но и по названию метода (так как у нас два Post-метода) [Route("api/[controller]/[action]")] [ApiController] public class ClientController : Controller { private readonly ILogger _logger; private readonly IClientLogic _logic; public ClientController(IClientLogic logic, ILogger logger) { _logger = logger; _logic = logic; } [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; } } } }