Beispiel #1
0
        public static IVision2RestResponse <S> ToVision2Response <S>(this IRestResponse <S> restResponse) where S : new()
        {
            var response = new Vision2RestResponse <S>();

            response.StatusCode   = restResponse.StatusCode;
            response.JsonResponse = restResponse.Content;
            response.Data         = restResponse.Data;

            return(response);
        }
Beispiel #2
0
        public static IVision2RestResponse ToVision2Response(this IRestResponse restResponse)
        {
            var response = new Vision2RestResponse();

            response.StatusCode   = restResponse.StatusCode;
            response.JsonResponse = restResponse.Content;

            if (restResponse.StatusCode != System.Net.HttpStatusCode.OK)
            {
                response.ErrorMessage = restResponse.ErrorMessage;
            }

            return(response);
        }
Beispiel #3
0
        private async Task <IVision2RestResponse <S> > ConvertResponseAsync <S>(HttpResponseMessage response) where S : new()
        {
            var vision2Response = new Vision2RestResponse <S> {
                StatusCode   = response.StatusCode,
                JsonResponse = await response.Content.ReadAsStringAsync()
            };

            if (!string.IsNullOrEmpty(vision2Response.JsonResponse) && (int)response.StatusCode > 300)
            {
                var responseError = Newtonsoft.Json.JsonConvert.DeserializeObject <dynamic>(vision2Response.JsonResponse);
                vision2Response.ErrorMessage = responseError.error_message;
            }
            else
            {
                vision2Response.Data = JsonConvert.DeserializeObject <S>(vision2Response.JsonResponse);
            }
            return(vision2Response);
        }
        /// <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 <IVision2RestResponse <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 response = await httpClient.PostAsync($"{options.SignInUrl}/token", content);

                var responseContent = await response.Content.ReadAsStringAsync();

                var v2Response = new Vision2RestResponse <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 if (responseContent.Replace("\"", "") == "null")
                {
                    v2Response.ErrorMessage = "Bad username / password";
                    v2Response.StatusCode   = System.Net.HttpStatusCode.BadRequest;
                }
                else
                {
                    v2Response.Data = responseContent.FromJson <Vision2Token>();
                }

                return(v2Response);
            }
        }
        public static async Task <IVision2RestResponse <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 response = await httpClient.PostAsync($"{options.SignInUrl}/token", content);

                    var responseContent = await response.Content.ReadAsStringAsync();

                    var v2Response = new Vision2RestResponse <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);
                }
            }
        }