/// <summary> /// Get Similar Users /// </summary> /// <param name="query">Required parameter: The query for similar users.</param> /// <return>Returns the UsersResponse response from the API call</return> public UsersResponse GetSimilarUsers(GetSimilarUsersBody query) { Task <UsersResponse> t = GetSimilarUsersAsync(query); APIHelper.RunTaskSynchronously(t); return(t.Result); }
/// <summary> /// Get Similar Users /// </summary> /// <param name="query">Required parameter: The query for similar users.</param> /// <return>Returns the UsersResponse response from the API call</return> public UsersResponse GetSimilarUsers(GetSimilarUsersBody query) { Task <UsersResponse> t = GetSimilarUsersAsync(query); Task.WaitAll(t); return(t.Result); }
/// <summary> /// Get Similar Users /// </summary> /// <param name="query">Required parameter: The query for similar users.</param> /// <return>Returns the UsersResponse response from the API call</return> public async Task <UsersResponse> GetSimilarUsersAsync(GetSimilarUsersBody query) { //the base uri for api requestss string _baseUri = Configuration.BaseUri; //prepare query string for API call StringBuilder _queryBuilder = new StringBuilder(_baseUri); _queryBuilder.Append("/v1/similar/users"); //validate and preprocess url string _queryUrl = APIHelper.CleanUrl(_queryBuilder); //append request with appropriate headers and parameters var _headers = new Dictionary <string, string>() { { "user-agent", "SUGGESTGRID" }, { "accept", "application/json" }, { "content-type", "application/json; charset=utf-8" } }; //append body params var _body = APIHelper.JsonSerialize(query); //prepare the API call request to fetch the response HttpRequest _request = ClientInstance.PostBody(_queryUrl, _headers, _body, Configuration.BasicAuthUserName, Configuration.BasicAuthPassword); //invoke request and get response HttpStringResponse _response = (HttpStringResponse)await ClientInstance.ExecuteAsStringAsync(_request).ConfigureAwait(false); HttpContext _context = new HttpContext(_request, _response); //Error handling using HTTP status codes if (_response.StatusCode == 400) { throw new ErrorResponseException(@"Request body is invalid.", _context); } else if (_response.StatusCode == 422) { throw new ErrorResponseException(@"Required parameters are missing.", _context); } else if (_response.StatusCode == 429) { throw new ErrorResponseException(@"Too many requests.", _context); } else if (_response.StatusCode == 500) { throw new APIException(@"Unexpected internal error.", _context); } //handle errors defined at the API level base.ValidateResponse(_response, _context); try { return(APIHelper.JsonDeserialize <UsersResponse>(_response.Body)); } catch (Exception _ex) { throw new APIException("Failed to parse the response: " + _ex.Message, _context); } }