using BankYouBankruptClientApp.Models; using BankYouBankruptContracts.BindingModels; using BankYouBankruptContracts.ViewModels; using BankYouBankruptContracts.ViewModels.Client.Default; using BankYouBankruptContracts.ViewModels.Client.Reports; using BankYouBankruptContracts.ViewModels.Client.Diagram; using BankYouBankruptDataModels.Enums; using BankYouBankruptСlientApp; using Microsoft.AspNetCore.Mvc; using PdfSharp.Drawing; using PdfSharp.Pdf; using PdfSharp.Pdf.IO; using System.Collections; using System.Diagnostics; using System.Reflection; using System.Xml.Linq; namespace BankYouBankruptClientApp.Controllers { public class HomeController : Controller { private readonly ILogger _logger; public HomeController(ILogger logger) { _logger = logger; } #region Профиль, вход и регистрация [HttpGet] public IActionResult Enter() { return View(); } [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)] public IActionResult Error() { return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier }); } [HttpGet] public IActionResult Login() { return View(); } [HttpPost] public void Login(string login, string password) { if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password)) { throw new Exception("Введите логин и пароль"); } APIClient.Client = APIClient.GetRequest($"api/Client/Login?login={login}&password={password}"); if (APIClient.Client == null) { throw new Exception("Неверный логин/пароль"); } Response.Redirect("Enter"); } [HttpGet] public IActionResult Register() { return View(); } [HttpPost] public void Register(string login, string password, string name, string surname, string patronymic, string telephone) { if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(name) || string.IsNullOrEmpty(surname) || string.IsNullOrEmpty(patronymic) || string.IsNullOrEmpty(telephone)) { throw new Exception("Введите логин, пароль, ФИО и телефон"); } APIClient.PostRequest("api/Client/Register", new ClientBindingModel { Name = name, Surname = surname, Patronymic = patronymic, Email = login, Password = password, Telephone = telephone }); Response.Redirect("Enter"); return; } [HttpPost] public IActionResult Logout() { APIClient.Client = null; return Redirect("~/Home/Enter"); } [HttpGet] public IActionResult Privacy() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } return View(APIClient.Client); } [HttpPost] public void Privacy(string login, string password, string name, string surname, string patronymic, string telephone) { if (APIClient.Client == null) { throw new Exception("Вы как сюда попали? Суда вход только авторизованным"); } if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(name) || string.IsNullOrEmpty(surname) || string.IsNullOrEmpty(patronymic) || string.IsNullOrEmpty(telephone)) { throw new Exception("Введите логин, пароль, ФИО и телефон"); } APIClient.PostRequest("/api/Client/UpdateData", new ClientBindingModel { Id = APIClient.Client.Id, Name = name, Surname = surname, Patronymic = patronymic, Telephone = telephone, Email = login, Password = password }); APIClient.Client.Name = name; APIClient.Client.Surname = surname; APIClient.Client.Patronymic = patronymic; APIClient.Client.Email = login; APIClient.Client.Password = password; APIClient.Client.Telephone = telephone; Response.Redirect("Enter"); } #endregion #region Карты [HttpGet] public IActionResult CardsList() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } return View(APIClient.GetRequest>($"api/Card/GetUsersCardsList?id={APIClient.Client.Id}")); } [HttpGet] public IActionResult CreateCard() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } ViewBag.Accounts = APIClient.GetRequest>($"api/Account/SearchAccountsOfCLient?clientId={APIClient.Client.Id}"); return View(); } [HttpPost] public IActionResult CreateCard(string accountId, string number, string cvc, string period) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Card/CreateCard", new CardBindingModel { ClientID = APIClient.Client.Id, AccountId = int.Parse(accountId), Number = number, CVC = cvc, Period = DateTime.Parse(period) }); return Redirect("~/Home/CardsList"); } #endregion #region Снятие средств [HttpGet] public IActionResult DebitingList() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } return View(APIClient.GetRequest>($"api/Client/getUsersDebitings?userId={APIClient.Client.Id}")); } [HttpGet] public IActionResult CreateDebiting() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } ViewBag.Cards = APIClient.GetRequest>($"api/Card/GetUsersCardsList?id={APIClient.Client.Id}"); return View(); } [HttpPost] public IActionResult CreateDebiting(string cardId, int sum) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Card/CreateDebitingRequest", new DebitingBindingModel() { CardId = int.Parse(cardId), Sum = sum, DateOpen = DateTime.Now, Status = StatusEnum.Открыта }); return Redirect("~/Home/DebitingList"); } #endregion #region Пополнение средств [HttpGet] public IActionResult CreditingList() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } return View(APIClient.GetRequest>($"api/Client/getUsersCreditings?userId={APIClient.Client.Id}")); } [HttpGet] public IActionResult CreateCrediting() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } ViewBag.Cards = APIClient.GetRequest>($"api/Card/GetUsersCardsList?id={APIClient.Client.Id}"); return View(); } [HttpPost] public IActionResult CreateCrediting(string cardId, int sum) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Card/CreateCreditingOperation", new CreditingBindingModel() { CardId = int.Parse(cardId), Sum = sum, DateOpen = DateTime.Now, Status = StatusEnum.Открыта }); return Redirect("~/Home/CreditingList"); } #endregion #region Получение отчёта PDF [HttpGet] public IActionResult CreateReport() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } return View(); } [HttpPost] public IActionResult CreateReport(DateTime dateFrom, DateTime dateTo) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } //ViewBag.DataOfClientReport = APIClient.GetRequest($"api/Report/GetDataOfClientReport"); return View(APIClient.PostRequestReport("api/Report/CreateClientReport", new ReportSupportBindingModel() { DateFrom = dateFrom, DateTo = dateTo, Email = APIClient.Client.Email })); } #endregion #region Excel отчёты //отчёт клиента по переводам [HttpPost] public IActionResult CreateExcelReport(List cards) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Report/CreateExcelClient", new ReportSupportBindingModel() { CardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList() }); return Redirect("~/Home/Enter"); } //отчёт клиента по пополнениям [HttpPost] public IActionResult CreateCreditingExcelReport(List cards) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Report/CreateExcelCrediting", new ReportSupportBindingModel() { CardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList() }); return Redirect("~/Home/Enter"); } //отчёт клиента по снятиям [HttpPost] public IActionResult CreateDebitingExcelReport(List cards) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Report/CreateExcelDebiting", new ReportSupportBindingModel() { CardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList() }); return Redirect("~/Home/Enter"); } #endregion #region Word отчёты клиента //отчёт клиента по переводам [HttpPost] public IActionResult CreateWordReport(List cards) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Report/CreateWordClient", new ReportSupportBindingModel() { CardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList() }); return Redirect("~/Home/Enter"); } //отчёт клиента по пополнениям [HttpPost] public IActionResult CreateCreditingWordReport(List cards) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Report/CreateWordCrediting", new ReportSupportBindingModel() { CardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList() }); return Redirect("~/Home/Enter"); } //отчёт клиента по снятиям [HttpPost] public IActionResult CreateDebitingWordReport(List cards) { if (APIClient.Client == null) { throw new Exception("Не авторизованы"); } APIClient.PostRequest("api/Report/CreateWordDebiting", new ReportSupportBindingModel() { CardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList() }); return Redirect("~/Home/Enter"); } #endregion #region Получение отчета по картам [HttpGet] public IActionResult ReportWithCards() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } return View(new ReportClientCardsViewModel() { Cards = APIClient.GetRequest>($"api/Card/GetUsersCardsList?id={APIClient.Client.Id}").Select(x => new CheckboxViewModel() { Id = x.Id, LabelName = x.Number, IsChecked = false }).ToList() }); } [HttpPost] public IActionResult ReportWithCards(List cards) { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } List cardList = cards.Where(x => x.IsChecked).Select(x => x.Id).ToList(); List creditings = APIClient.GetRequest>($"api/Client/getUsersCreditings?userId={APIClient.Client.Id}") .Where(x => cardList.Contains(x.CardId)).Select(x => new ReportViewModel() { Id = x.Id, CardId = x.CardId, DateOpen = x.DateOpen, DateClose = x.DateClose, CardNumber = x.CardNumber, Status = x.Status, Sum = x.Sum, TypeOperation = TypeOperationEnum.Пополнение }).ToList(); List debitings = APIClient.GetRequest>($"api/Client/getUsersDebitings?userId={APIClient.Client.Id}") .Where(x => cardList.Contains(x.CardId)).Select(x => new ReportViewModel() { Id = x.Id, CardId = x.CardId, DateOpen = x.DateOpen, DateClose = x.DateClose, CardNumber = x.CardNumber, Status = x.Status, Sum = x.Sum, TypeOperation = TypeOperationEnum.Снятие }).ToList(); List result = creditings.Concat(debitings).OrderBy(x => x.DateOpen).ToList(); return View(new ReportClientCardsViewModel() { Cards = cards, Operations = result, }); } #endregion #region Диаграмма [HttpGet] public IActionResult Diagram() { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } ViewBag.Cards = APIClient.GetRequest>($"api/Card/GetUsersCardsList?id={APIClient.Client.Id}"); return View(); } [HttpPost] public IActionResult Diagram(int cardId) { if (APIClient.Client == null) { return Redirect("~/Home/Enter"); } ViewBag.Cards = APIClient.GetRequest>($"api/Card/GetUsersCardsList?id={APIClient.Client.Id}"); return View(new ClientDiagramViewModel() { DiagramName = "Hello World", Elements = APIClient.GetRequest>($"api/Card/getCardMonthResult?cardId={cardId}") }); } #endregion } }