using DocumentFormat.OpenXml.Wordprocessing; using HotelContracts.BindingModels; using HotelContracts.ViewModels; using HotelOrganiserApp.Models; using Microsoft.AspNetCore.Mvc; using System.Diagnostics; namespace HotelOrganiserApp.Controllers { public class HomeController : Controller { private readonly ILogger _logger; public HomeController(ILogger logger) { _logger = logger; } public IActionResult Index() { if (APIClient.Organiser == null) { return Redirect("~/Home/Enter"); } return View(); } public IActionResult Register() { return View(); } [HttpPost] public void Register(string login, string email, string password, string surname, string name, string patronymic, string telephone) { if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(surname) || string.IsNullOrEmpty(name) || string.IsNullOrEmpty(patronymic)) { throw new Exception("Введите логин, пароль, фамилию, имя и отчество"); } APIClient.PostRequest("api/organiser/register", new OrganiserBindingModel { OrganiserSurname = surname, OrganiserName = name, OrganiserPatronymic = patronymic, OrganiserLogin = login, OrganiserPassword = password, OrganiserEmail = email, OrganiserPhoneNumber = telephone }); Response.Redirect("Enter"); return; } public IActionResult Enter() { return View(); } [HttpPost] public void Enter(string login, string password) { if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password)) { throw new Exception("Введите логин и пароль"); } APIClient.Organiser = APIClient.GetRequest($"api/organiser/login?login={login}&password={password}"); if (APIClient.Organiser == null) { throw new Exception("Неверный логин/пароль"); } Response.Redirect("Index"); } public IActionResult Privacy() { if (APIClient.Organiser == null) { return Redirect("~/Home/Enter"); } return View(APIClient.Organiser); } [HttpPost] public void Privacy(string login, string email, string password, string surname, string name, string patronymic, string telephone) { if (APIClient.Organiser == null) { throw new Exception("Вы как сюда попали? Сюда вход только авторизованным"); } if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(surname) || string.IsNullOrEmpty(name) || string.IsNullOrEmpty(patronymic)) { throw new Exception("Введите логин, пароль, фамилию, имя и отчество"); } APIClient.PostRequest("api/organiser/updatedata", new OrganiserBindingModel { Id = APIClient.Organiser.Id, OrganiserSurname = surname, OrganiserName = name, OrganiserPatronymic = patronymic, OrganiserLogin = login, OrganiserPassword = password, OrganiserEmail = email, OrganiserPhoneNumber = telephone }); APIClient.Organiser.OrganiserSurname = surname; APIClient.Organiser.OrganiserName = name; APIClient.Organiser.OrganiserPatronymic = patronymic; APIClient.Organiser.OrganiserLogin = login; APIClient.Organiser.OrganiserPassword = password; APIClient.Organiser.OrganiserEmail = email; APIClient.Organiser.OrganiserPhoneNumber = telephone; Response.Redirect("Index"); } public IActionResult ListMembers() { if (APIClient.Organiser == null) { return Redirect("~/Home/Enter"); } return View(APIClient.GetRequest>($"api/member/getmemberlist?organiserId={APIClient.Organiser.Id}")); } public IActionResult CreateMember() { if (APIClient.Organiser == null) { return Redirect("~/Home/Enter"); } return View(); } [HttpPost] public void CreateMember(string memberSurname, string memberName, string memberPatronymic, string memberPhoneNumber) { if (APIClient.Organiser == null) { throw new Exception("Необходима авторизация"); } if (string.IsNullOrEmpty(memberSurname) || string.IsNullOrEmpty(memberName) || string.IsNullOrEmpty(memberPatronymic) || string.IsNullOrEmpty(memberPhoneNumber)) { throw new Exception("Введите фамилию, имя, отчество и номер телефона"); } APIClient.PostRequest("api/member/createmember", new MemberBindingModel { MemberSurname = memberSurname, MemberName = memberName, MemberPatronymic = memberPatronymic, MemberPhoneNumber = memberPhoneNumber, OrganiserId = APIClient.Organiser.Id, }); Response.Redirect("ListMembers"); } public IActionResult UpdateMember() { if (APIClient.Organiser == null) { return Redirect("~/Home/Enter"); } ViewBag.Members = APIClient.GetRequest>($"api/member/getmemberlist?organiserId={APIClient.Organiser.Id}"); return View(); } [HttpPost] public void UpdateMember(int member, string memberSurname, string memberName, string memberPatronymic, string memberPhoneNumber) { if (APIClient.Organiser == null) { throw new Exception("Необходима авторизация"); } if (string.IsNullOrEmpty(memberSurname)) { throw new Exception("Фамилия не может быть пустая"); } if (string.IsNullOrEmpty(memberName)) { throw new Exception("Имя не может быть пустым"); } if (string.IsNullOrEmpty(memberPatronymic)) { throw new Exception("Отчество не может быть пустым"); } if (string.IsNullOrEmpty(memberPhoneNumber)) { throw new Exception("Номер телефона не может быть пустым"); } APIClient.PostRequest("api/member/updatemember", new MemberBindingModel { Id = member, MemberSurname = memberSurname, MemberName = memberName, MemberPatronymic = memberPatronymic, MemberPhoneNumber = memberPhoneNumber, OrganiserId = APIClient.Organiser.Id, }); Response.Redirect("ListMembers"); } public IActionResult DeleteMember() { if (APIClient.Organiser == null) { return Redirect("~/Home/Enter"); } ViewBag.Members = APIClient.GetRequest>($"api/member/getmemberlist?organiserId={APIClient.Organiser.Id}"); return View(); } [HttpPost] public void DeleteMember(int member) { if (APIClient.Organiser == null) { throw new Exception("Необходима авторизация"); } APIClient.PostRequest("api/member/deletemember", new MemberBindingModel { Id = member }); Response.Redirect("ListMembers"); } [HttpGet] public MemberViewModel? GetMember(int memberId) { if (APIClient.Organiser == null) { throw new Exception("Необходима авторизация"); } var result = APIClient.GetRequest($"api/member/getmember?memberid={memberId}"); if (result == null) { return default; } var memberSurname = result.MemberSurname; var memberName = result.MemberName; var memberPatronymic = result.MemberPatronymic; var memberPhoneNumber = result.MemberPhoneNumber; return result; } [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)] public IActionResult Error() { return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier }); } } }