190 lines
6.1 KiB
C#
190 lines
6.1 KiB
C#
using SecuritySystemClientApp.Models;
|
||
using SecuritySystemContracts.BindingModels;
|
||
using SecuritySystemContracts.ViewModels;
|
||
using Microsoft.AspNetCore.Mvc;
|
||
using System.Diagnostics;
|
||
|
||
namespace SecuritySystemClientApp.Controllers
|
||
{
|
||
public class HomeController : Controller
|
||
{
|
||
private readonly ILogger<HomeController> _logger;
|
||
|
||
public HomeController(ILogger<HomeController> logger)
|
||
{
|
||
_logger = logger;
|
||
}
|
||
|
||
//вытаскивает через API клиента Get-запросом список его собственных заказов
|
||
public IActionResult Index()
|
||
{
|
||
if (APIClient.Client == null)
|
||
{
|
||
return Redirect("~/Home/Enter");
|
||
}
|
||
|
||
return View(APIClient.GetRequest<List<OrderViewModel>>($"api/main/getorders?clientId={APIClient.Client.Id}"));
|
||
}
|
||
|
||
//изменемение ланных Get-ом
|
||
[HttpGet]
|
||
public IActionResult Privacy()
|
||
{
|
||
if (APIClient.Client == null)
|
||
{
|
||
return Redirect("~/Home/Enter");
|
||
}
|
||
|
||
return View(APIClient.Client);
|
||
}
|
||
|
||
//изменение данных Post-ом
|
||
[HttpPost]
|
||
public void Privacy(string login, string password, string fio)
|
||
{
|
||
if (APIClient.Client == null)
|
||
{
|
||
throw new Exception("Вы как сюда попали? Суда вход только авторизованным");
|
||
}
|
||
|
||
if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(fio))
|
||
{
|
||
throw new Exception("Введите логин, пароль и ФИО");
|
||
}
|
||
|
||
APIClient.PostRequest("api/client/updatedata", new ClientBindingModel
|
||
{
|
||
Id = APIClient.Client.Id,
|
||
ClientFIO = fio,
|
||
Email = login,
|
||
Password = password
|
||
});
|
||
|
||
APIClient.Client.ClientFIO = fio;
|
||
APIClient.Client.Email = login;
|
||
APIClient.Client.Password = password;
|
||
|
||
Response.Redirect("Index");
|
||
}
|
||
|
||
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
|
||
public IActionResult Error()
|
||
{
|
||
return View(new ErrorViewModel
|
||
{
|
||
RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier
|
||
});
|
||
}
|
||
|
||
//просто открытие вьюхи
|
||
[HttpGet]
|
||
public IActionResult Enter()
|
||
{
|
||
return View();
|
||
}
|
||
|
||
//отсылаем указанные данные на проверку
|
||
[HttpPost]
|
||
public void Enter(string login, string password)
|
||
{
|
||
if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password))
|
||
{
|
||
throw new Exception("Введите логин и пароль");
|
||
}
|
||
|
||
APIClient.Client = APIClient.GetRequest<ClientViewModel>($"api/client/login?login={login}&password={password}");
|
||
|
||
if (APIClient.Client == null)
|
||
{
|
||
throw new Exception("Неверный логин/пароль");
|
||
}
|
||
|
||
Response.Redirect("Index");
|
||
}
|
||
|
||
//просто открытие вьюхи
|
||
[HttpGet]
|
||
public IActionResult Register()
|
||
{
|
||
return View();
|
||
}
|
||
|
||
//Post-запрос по созданию нового пользователя
|
||
[HttpPost]
|
||
public void Register(string login, string password, string fio)
|
||
{
|
||
if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(fio))
|
||
{
|
||
throw new Exception("Введите логин, пароль и ФИО");
|
||
}
|
||
|
||
APIClient.PostRequest("api/client/register", new ClientBindingModel
|
||
{
|
||
ClientFIO = fio,
|
||
Email = login,
|
||
Password = password
|
||
});
|
||
|
||
//переход на вкладку "Enter", чтобы пользователь сразу смог зайти
|
||
Response.Redirect("Enter");
|
||
|
||
return;
|
||
}
|
||
|
||
//создание заказа. Получаем и передаём список изделий во вьюху?
|
||
[HttpGet]
|
||
public IActionResult Create()
|
||
{
|
||
ViewBag.Secures = APIClient.GetRequest<List<SecureViewModel>>("api/main/getsecurelist");
|
||
|
||
return View();
|
||
}
|
||
|
||
//создание заказа Post-запросом
|
||
[HttpPost]
|
||
public void Create(int secure, int count)
|
||
{
|
||
if (APIClient.Client == null)
|
||
{
|
||
throw new Exception("Вы как сюда попали? Суда вход только авторизованным");
|
||
}
|
||
|
||
if (count <= 0)
|
||
{
|
||
throw new Exception("Количество и сумма должны быть больше 0");
|
||
}
|
||
|
||
APIClient.PostRequest("api/main/createorder", new OrderBindingModel
|
||
{
|
||
ClientId = APIClient.Client.Id,
|
||
SecureId = secure,
|
||
Count = count,
|
||
Sum = Calc(count, secure)
|
||
});
|
||
|
||
Response.Redirect("Index");
|
||
}
|
||
|
||
//подсчёт стоимости заказа
|
||
[HttpPost]
|
||
public double Calc(int count, int secure)
|
||
{
|
||
var manuf = APIClient.GetRequest<SecureViewModel>($"api/main/getsecure?secureId={secure}"
|
||
);
|
||
|
||
return count * (manuf?.Price ?? 1);
|
||
}
|
||
|
||
//для работы с письмами
|
||
[HttpGet]
|
||
public IActionResult Mails()
|
||
{
|
||
if (APIClient.Client == null)
|
||
{
|
||
return Redirect("~/Home/Enter");
|
||
}
|
||
|
||
return View(APIClient.GetRequest<List<MessageInfoViewModel>>($"api/client/getmessages?clientId={APIClient.Client.Id}"));
|
||
}
|
||
}
|
||
} |