Added Poll response function
JSON is not properly serialised... still in progress
This commit is contained in:
parent
e134751745
commit
5a2f109e65
@ -12,7 +12,7 @@ namespace EFB.Controllers.API
|
|||||||
{
|
{
|
||||||
private HttpClient HttpClient { get; set; }
|
private HttpClient HttpClient { get; set; }
|
||||||
|
|
||||||
public async Task<ResponseModel> Get<T>(string Endpoint, Dictionary<string, string> Headers){
|
public async Task<ResponseModel<T>> Get<T>(string Endpoint, Dictionary<string, string> Headers){
|
||||||
|
|
||||||
this.HttpClient = new HttpClient();
|
this.HttpClient = new HttpClient();
|
||||||
|
|
||||||
@ -36,32 +36,31 @@ namespace EFB.Controllers.API
|
|||||||
|
|
||||||
string resultString = result.Content.ReadAsStringAsync().Result;
|
string resultString = result.Content.ReadAsStringAsync().Result;
|
||||||
|
|
||||||
object response;
|
|
||||||
|
|
||||||
//Assess return value (object or raw string)
|
//Assess return value (object or raw string)
|
||||||
try{
|
object response = resultString;
|
||||||
|
|
||||||
|
if (typeof(T) != typeof(string))
|
||||||
|
{//If the user requests string for return type
|
||||||
response = JsonConvert.DeserializeObject<T>(resultString);
|
response = JsonConvert.DeserializeObject<T>(resultString);
|
||||||
}catch {
|
|
||||||
response = resultString;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ResponseModel{
|
return new ResponseModel<T>(){
|
||||||
//Sender should be aware of type T becuase of Generic function
|
//Sender should be aware of type T becuase of Generic type
|
||||||
Result = response
|
Result = (T)response
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (System.Exception e)
|
||||||
{
|
{
|
||||||
return new ResponseModel{Error = e.Message};
|
return new ResponseModel<T>{Error = e.Message};
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
//Returned in the event No other response has been returned
|
//Returned in the event No other response has been returned
|
||||||
return new ResponseModel{Error = "Invalid Endpoint - Please try again later"};
|
return new ResponseModel<T>{Error = "Invalid Endpoint - Please try again later"};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<ResponseModel> Post<T>(string Endpoint, Dictionary<string, string> Headers, HttpContent Body){
|
public async Task<ResponseModel<T>> Post<T>(string Endpoint, Dictionary<string, string> Headers, HttpContent Body){
|
||||||
|
|
||||||
this.HttpClient = new HttpClient();
|
this.HttpClient = new HttpClient();
|
||||||
this.HttpClient.DefaultRequestHeaders.Clear();
|
this.HttpClient.DefaultRequestHeaders.Clear();
|
||||||
@ -88,16 +87,58 @@ namespace EFB.Controllers.API
|
|||||||
response = JsonConvert.DeserializeObject<T>(resultString);
|
response = JsonConvert.DeserializeObject<T>(resultString);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ResponseModel(){
|
return new ResponseModel<T>(){
|
||||||
//Sender should be aware of type T becuase of Generic function
|
//Sender should be aware of type T becuase of Generic type
|
||||||
Result = response
|
Result = (T)response
|
||||||
};
|
};
|
||||||
}catch(System.Exception e){
|
}catch(System.Exception e){
|
||||||
return new ResponseModel{Error = e.Message};
|
return new ResponseModel<T>{Error = e.Message};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Returned in the event No other response has been returned
|
//Returned in the event No other response has been returned
|
||||||
return new ResponseModel{Error = "Invalid Endpoint - Please try again later"};
|
return new ResponseModel<T>{Error = "Invalid Endpoint - Please try again later"};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public async Task<ResponseModel<T>> Put<T>(string Endpoint, Dictionary<string, string> Headers, HttpContent Body){
|
||||||
|
|
||||||
|
this.HttpClient = new HttpClient();
|
||||||
|
this.HttpClient.DefaultRequestHeaders.Clear();
|
||||||
|
|
||||||
|
if (Headers != null)
|
||||||
|
{
|
||||||
|
foreach (var Header in Headers)
|
||||||
|
{
|
||||||
|
this.HttpClient.DefaultRequestHeaders.Add(Header.Key, Header.Value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Form.FormAuthenticator.ValidateEndpoint(Endpoint))
|
||||||
|
{
|
||||||
|
try{//Try statement to catch errors in the process of making the request
|
||||||
|
var pendingResult = this.HttpClient.PutAsync(Endpoint, Body);
|
||||||
|
var result = await pendingResult;
|
||||||
|
string resultString = result.Content.ReadAsStringAsync().Result;
|
||||||
|
|
||||||
|
object response = resultString;
|
||||||
|
|
||||||
|
if (typeof(T) != typeof(string))
|
||||||
|
{//If the user requests string for return type
|
||||||
|
response = JsonConvert.DeserializeObject<T>(resultString);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ResponseModel<T>(){
|
||||||
|
//Sender should be aware of type T becuase of Generic type
|
||||||
|
Result = (T)response
|
||||||
|
};
|
||||||
|
}catch(System.Exception e){
|
||||||
|
return new ResponseModel<T>{Error = e.Message};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Returned in the event No other response has been returned
|
||||||
|
return new ResponseModel<T>{Error = "Invalid Endpoint - Please try again later"};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ namespace EFB.Controllers
|
|||||||
//Make initial Route Request
|
//Make initial Route Request
|
||||||
var requestRoute = API.Post<string>("https://api.autorouter.aero/v1.0/router", headerData, content);
|
var requestRoute = API.Post<string>("https://api.autorouter.aero/v1.0/router", headerData, content);
|
||||||
|
|
||||||
ResponseModel responseRoute = await requestRoute;
|
ResponseModel<string> responseRoute = await requestRoute;
|
||||||
|
|
||||||
if (responseRoute.Error == null)
|
if (responseRoute.Error == null)
|
||||||
{//Update User session and add route ID
|
{//Update User session and add route ID
|
||||||
@ -83,6 +83,8 @@ namespace EFB.Controllers
|
|||||||
user.Route = route;
|
user.Route = route;
|
||||||
HttpContext.Session.SetObject("User", user);
|
HttpContext.Session.SetObject("User", user);
|
||||||
|
|
||||||
|
return await Poll();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TempData["Error"] = responseRoute.Error;
|
TempData["Error"] = responseRoute.Error;
|
||||||
@ -105,12 +107,33 @@ namespace EFB.Controllers
|
|||||||
public async Task<IActionResult> Poll(){
|
public async Task<IActionResult> Poll(){
|
||||||
if (HttpContext.Session.GetString("User") != null)
|
if (HttpContext.Session.GetString("User") != null)
|
||||||
{//If the user is currently logged in
|
{//If the user is currently logged in
|
||||||
UserModel User = HttpContext.Session.GetObject<UserModel>("User");
|
UserModel user = HttpContext.Session.GetObject<UserModel>("User");
|
||||||
|
|
||||||
if (User.Route != null)
|
if (user.Route != null)
|
||||||
{//If the user has a route object (e.g, they have been to the route page)
|
{//If the user has a route object (e.g, they have been to the route page)
|
||||||
|
|
||||||
//Make calls to the server to fetch route
|
//Make calls to the server to fetch route
|
||||||
|
bool collected = false;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
APIInterface API = new APIInterface();
|
||||||
|
|
||||||
|
Dictionary<string, string> headerData = new Dictionary<string, string>();
|
||||||
|
headerData.Add("Authorization", $"Bearer {user.Token.TokenValue}");
|
||||||
|
|
||||||
|
while (collected == false && count <= 5)
|
||||||
|
{
|
||||||
|
count ++;
|
||||||
|
|
||||||
|
//Make Polling Request
|
||||||
|
var pollingRequest = API.Put<List<PollResponse>>($"https://api.autorouter.aero/v1.0/router/{user.Route.RouteID}/longpoll", headerData, null);
|
||||||
|
|
||||||
|
ResponseModel<List<PollResponse>> responsePoll = await pollingRequest;
|
||||||
|
|
||||||
|
Console.WriteLine(responsePoll);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
return RedirectToAction("Index", "Route");
|
return RedirectToAction("Index", "Route");
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
|
@ -47,7 +47,7 @@ namespace EFB.Controllers
|
|||||||
var request = API.Post<Models.JSON.LoginResponse>("https://api.autorouter.aero/v1.0/oauth2/token", null, content);
|
var request = API.Post<Models.JSON.LoginResponse>("https://api.autorouter.aero/v1.0/oauth2/token", null, content);
|
||||||
|
|
||||||
//Wait for the response to come through
|
//Wait for the response to come through
|
||||||
ResponseModel response = await request;
|
ResponseModel<LoginResponse> response = await request;
|
||||||
|
|
||||||
if (response.Error != null)
|
if (response.Error != null)
|
||||||
{
|
{
|
||||||
@ -57,7 +57,7 @@ namespace EFB.Controllers
|
|||||||
}else{
|
}else{
|
||||||
|
|
||||||
//Type cast required but we know response will be of known type
|
//Type cast required but we know response will be of known type
|
||||||
LoginResponse login = (LoginResponse)response.Result;
|
LoginResponse login = response.Result;
|
||||||
|
|
||||||
//Generate User Session
|
//Generate User Session
|
||||||
if (login.error == null)
|
if (login.error == null)
|
||||||
|
19
Models/JSON/PollResponse.cs
Normal file
19
Models/JSON/PollResponse.cs
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
|
namespace EFB.Models.JSON
|
||||||
|
{
|
||||||
|
[JsonArray]
|
||||||
|
public class PollResponse
|
||||||
|
{
|
||||||
|
[JsonProperty(PropertyName = "cmdname")]
|
||||||
|
public string Command { get; set; }
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "fpl")]
|
||||||
|
public string FlightPlan { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -5,11 +5,10 @@ using System.Threading.Tasks;
|
|||||||
|
|
||||||
namespace EFB.Models
|
namespace EFB.Models
|
||||||
{
|
{
|
||||||
public class ResponseModel
|
public class ResponseModel<T>
|
||||||
{
|
{
|
||||||
//Object should be of known type from sender
|
//Object should be of known type from sender
|
||||||
public object Result { get; set; } = null;
|
public T Result { get; set; } = default(T);
|
||||||
|
|
||||||
public string Error { get; set; } = null;
|
public string Error { get; set; } = null;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user