EFB/Controllers/UserController.cs

104 lines
3.4 KiB
C#
Raw Normal View History

2021-10-31 18:58:30 +00:00
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using System.Net.Http;
using EFB.Models.JSON;
using Microsoft.Extensions.Logging;
using EFB.Models;
using EFB.Sessions;
2022-02-09 18:11:00 +00:00
using EFB.Controllers.API;
2021-10-31 18:58:30 +00:00
namespace EFB.Controllers
{
//[Route("[controller]")]
public class UserController : Controller
{
private readonly ILogger<UserController> _logger;
public UserController(ILogger<UserController> logger)
{
_logger = logger;
}
public IActionResult Index()
{
return View();
}
public async Task<IActionResult> Login(string email, string password){
if (Form.FormAuthenticator.ValidateEMail(email))
{
//API Helper
2022-02-09 18:11:00 +00:00
APIInterface API = new APIInterface();
2021-10-31 18:58:30 +00:00
//Dictionary of Formdata to be encoded
Dictionary<string, string> formData = new Dictionary<string, string>();
formData.Add("grant_type", "client_credentials");
formData.Add("client_id", email);
formData.Add("client_secret", password);
HttpContent content = new FormUrlEncodedContent(formData);
var request = API.Post<Models.JSON.LoginResponse>("https://api.autorouter.aero/v1.0/oauth2/token", null, content);
//Wait for the response to come through
ResponseModel<LoginResponse> response = await request;
2021-10-31 18:58:30 +00:00
if (response.Error != null)
2021-10-31 18:58:30 +00:00
{
TempData["Error"] = response.Error;
TempData["email"] = email;
2021-10-31 18:58:30 +00:00
return RedirectToAction("Index", "Home");
}else{
//Type cast required but we know response will be of known type
LoginResponse login = response.Result;
//Generate User Session
if (login.error == null)
{
UserModel user = new UserModel{
EMail = email,
2022-01-09 15:36:52 +00:00
UserToken = new TokenModel{
TokenValue = login.access_token,
Expiration = DateTime.UtcNow.AddSeconds(login.expires_in)
}
};
//Using Session Extensions (Store the user session)
HttpContext.Session.SetObject("User", user);
2021-11-15 07:44:18 +00:00
return RedirectToAction("Index", "App");
}else{
TempData["Error"] = login.error_description;
TempData["email"] = email;
return RedirectToAction("Index", "Home");
}
2021-10-31 18:58:30 +00:00
}
}else{
TempData["Error"] = "Please enter a valid E-Mail";
return RedirectToAction("Index", "Home");
}
}
2022-02-07 20:58:32 +00:00
public IActionResult Logout(){
HttpContext.Session.SetObject("User", null);
return RedirectToAction("Index", "Home");
}
2021-10-31 18:58:30 +00:00
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult Error()
{
return View("Error!");
}
}
}