102 lines
2.4 KiB
C#
Raw Normal View History

2024-03-31 11:37:27 +04:00
using HotelContracts.BindingModels;
using HotelContracts.BusinessLogicsContracts;
using HotelContracts.SearchModels;
using HotelContracts.ViewModels;
2024-04-30 22:30:12 +04:00
using HotelDataBaseImplement.Models;
2024-03-31 11:37:27 +04:00
using Microsoft.AspNetCore.Mvc;
namespace HotelRestApi.Controllers
{
2024-03-31 22:00:39 +04:00
[Route("api/[controller]/[action]")]
[ApiController]
2024-03-31 11:37:27 +04:00
public class MemberController : Controller
{
private readonly ILogger _logger;
private readonly IMemberLogic _member;
public MemberController(ILogger<MemberController> logger, IMemberLogic member)
{
_logger = logger;
_member = member;
}
2024-04-30 22:30:12 +04:00
[HttpGet]
public List<MemberViewModel>? GetMembers(int? organiserId = null)
{
try
{
if (!organiserId.HasValue)
{
return _member.ReadList(null);
}
return _member.ReadList(new MemberSearchModel
{
OrganiserId = organiserId
});
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка получения списка участников");
throw;
}
}
2024-03-31 11:37:27 +04:00
2024-04-30 22:30:12 +04:00
[HttpGet]
2024-05-02 00:55:35 +04:00
public MemberViewModel GetMember(int memberId)
2024-04-30 22:30:12 +04:00
{
try
{
2024-05-02 00:55:35 +04:00
var elem = _member.ReadElement(new MemberSearchModel { Id = memberId });
2024-04-30 22:30:12 +04:00
return elem;
}
catch (Exception ex)
{
2024-05-02 00:55:35 +04:00
_logger.LogError(ex, "Ошибка получения участника по id={Id}", memberId);
2024-04-30 22:30:12 +04:00
throw;
}
}
2024-03-31 11:37:27 +04:00
2024-04-30 22:30:12 +04:00
[HttpPost]
2024-03-31 11:37:27 +04:00
public void CreateMember(MemberBindingModel model)
{
try
{
_member.Create(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка создания участника");
throw;
}
}
[HttpPost]
public void UpdateMember(MemberBindingModel model)
{
try
{
_member.Update(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка обновления данных");
throw;
}
}
[HttpPost]
public void DeleteMember(MemberBindingModel model)
{
try
{
_member.Delete(model);
}
catch (Exception ex)
{
_logger.LogError(ex, "Ошибка удаления участника");
throw;
}
}
}
}