public static IVision2Response ToVision2Response(this IRestResponse restResponse) { var response = new Vision2Response(); response.StatusCode = restResponse.StatusCode; response.JsonResponse = restResponse.Content; if (restResponse.StatusCode != System.Net.HttpStatusCode.OK) { response.ErrorMessage = restResponse.ErrorMessage; } return(response); }
public static IVision2Response <S> ToVision2Response <S>(this IRestResponse <S> restResponse) where S : new() { var response = new Vision2Response <S>(); response.StatusCode = restResponse.StatusCode; response.JsonResponse = restResponse.Content; if ((int)restResponse.StatusCode >= 300) { response.ErrorMessage = restResponse.ErrorMessage; } else { response.Data = restResponse.Data; } return(response); }
public static async Task <IVision2Response <Vision2Token> > RefreshAccessTokenAsync(Vision2Options options, string refreshToken) { System.Net.ServicePointManager.SecurityProtocol = System.Net.SecurityProtocolType.Tls12 | System.Net.SecurityProtocolType.Tls11; using (var httpClient = new HttpClient()) { try { var content = new FormUrlEncodedContent(new[] { new KeyValuePair <string, string>("grant_type", "refresh_token"), new KeyValuePair <string, string>("refresh_token", refreshToken), }); var url = new Uri(options.IsStaging ? $"https://{options.TenantCode}.v2sdemo.com" : $"https://{options.TenantCode}.vision2systems.com"); var response = await httpClient.PostAsync($"{url}/token", content); var responseContent = await response.Content.ReadAsStringAsync(); var v2Response = new Vision2Response <Vision2Token> { StatusCode = response.StatusCode, RequestValue = Newtonsoft.Json.JsonConvert.SerializeObject(content) }; if (!string.IsNullOrEmpty(responseContent) && responseContent.Contains("error")) { var responseError = responseContent.FromJson <dynamic>(); v2Response.ErrorMessage = responseError.error_message; } else { v2Response.Data = responseContent.FromJson <Vision2Token>(); } return(v2Response); } catch (Exception e) { return(null); } } }
/// <summary> /// Request an access token from Vision2 /// </summary> /// <param name="options">Options for the Vision2 Client</param> /// <param name="username">The username to authenticate</param> /// <param name="password">The password to authenticate /// <returns>An OAuth Token object to use for subsequent requests</returns> public static async Task <IVision2Response <Vision2Token> > RequestAccessTokenAsync(Vision2Options options) { System.Net.ServicePointManager.SecurityProtocol = System.Net.SecurityProtocolType.Tls12 | System.Net.SecurityProtocolType.Tls11; using (var httpClient = new HttpClient()) { var content = new FormUrlEncodedContent(new[] { new KeyValuePair <string, string>("grant_type", "password"), new KeyValuePair <string, string>("username", options.Username), new KeyValuePair <string, string>("password", options.Password), }); var url = new Uri(options.IsStaging ? $"https://{options.TenantCode}.v2sdemo.com" : $"https://{options.TenantCode}.vision2systems.com"); // httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", System.Convert.ToBase64String(toEncodeAsBytes, 0, toEncodeAsBytes.Length)); var response = await httpClient.PostAsync($"{url}/token", content); var responseContent = await response.Content.ReadAsStringAsync(); var v2Response = new Vision2Response <Vision2Token> { StatusCode = response.StatusCode, RequestValue = Newtonsoft.Json.JsonConvert.SerializeObject(content) }; if (!string.IsNullOrEmpty(responseContent) && responseContent.Contains("error")) { var responseError = responseContent.FromJson <dynamic>(); v2Response.ErrorMessage = responseError.error_message; } else { v2Response.Data = responseContent.FromJson <Vision2Token>(); } return(v2Response); } }