Created
October 30, 2015 19:33
-
-
Save brenovieira/97854a602657292d60c9 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Code generated by Microsoft (R) AutoRest Code Generator 0.12.0.0 | |
// Changes may cause incorrect behavior and will be lost if the code is | |
// regenerated. | |
namespace API.Client | |
{ | |
using System; | |
using System.Linq; | |
using System.Collections.Generic; | |
using System.Net; | |
using System.Net.Http; | |
using System.Net.Http.Headers; | |
using System.Text; | |
using System.Text.RegularExpressions; | |
using System.Threading; | |
using System.Threading.Tasks; | |
using Microsoft.Rest; | |
using Microsoft.Rest.Serialization; | |
using Newtonsoft.Json; | |
using Models; | |
/// <summary> | |
/// ActionOperations operations. | |
/// </summary> | |
public partial class ActionOperations : IServiceOperations<ArenaAPIClient>, IActionOperations | |
{ | |
/// <summary> | |
/// Initializes a new instance of the ActionOperations class. | |
/// </summary> | |
/// <param name='client'> | |
/// Reference to the service client. | |
/// </param> | |
public ActionOperations(APIClient client) | |
{ | |
if (client == null) | |
{ | |
throw new ArgumentNullException("client"); | |
} | |
this.Client = client; | |
} | |
/// <summary> | |
/// Gets a reference to the APIClient | |
/// </summary> | |
public APIClient Client { get; private set; } | |
/// <summary> | |
/// Get all actions | |
/// </summary> | |
/// <param name='authorization'> | |
/// Access Token | |
/// </param> | |
/// <param name='customHeaders'> | |
/// Headers that will be added to request. | |
/// </param> | |
/// <param name='cancellationToken'> | |
/// The cancellation token. | |
/// </param> | |
public async Task<HttpOperationResponse<IList<Action>>> GetWithHttpMessagesAsync(string authorization, Dictionary<string, List<string>> customHeaders = null, CancellationToken cancellationToken = default(CancellationToken)) | |
{ | |
if (authorization == null) | |
{ | |
throw new ValidationException(ValidationRules.CannotBeNull, "authorization"); | |
} | |
// Tracing | |
bool shouldTrace = ServiceClientTracing.IsEnabled; | |
string invocationId = null; | |
if (shouldTrace) | |
{ | |
invocationId = ServiceClientTracing.NextInvocationId.ToString(); | |
Dictionary<string, object> tracingParameters = new Dictionary<string, object>(); | |
tracingParameters.Add("authorization", authorization); | |
tracingParameters.Add("cancellationToken", cancellationToken); | |
ServiceClientTracing.Enter(invocationId, this, "Get", tracingParameters); | |
} | |
// Construct URL | |
var baseUrl = this.Client.BaseUri.AbsoluteUri; | |
var url = new Uri(new Uri(baseUrl + (baseUrl.EndsWith("/") ? "" : "/")), "api/actions").ToString(); | |
// Create HTTP transport objects | |
HttpRequestMessage httpRequest = new HttpRequestMessage(); | |
httpRequest.Method = new HttpMethod("GET"); | |
httpRequest.RequestUri = new Uri(url); | |
// Set Headers | |
if (authorization != null) | |
{ | |
if (httpRequest.Headers.Contains("Authorization")) | |
{ | |
httpRequest.Headers.Remove("Authorization"); | |
} | |
httpRequest.Headers.TryAddWithoutValidation("Authorization", authorization); | |
} | |
if (customHeaders != null) | |
{ | |
foreach(var header in customHeaders) | |
{ | |
if (httpRequest.Headers.Contains(header.Key)) | |
{ | |
httpRequest.Headers.Remove(header.Key); | |
} | |
httpRequest.Headers.TryAddWithoutValidation(header.Key, header.Value); | |
} | |
} | |
// Set Credentials | |
if (this.Client.Credentials != null) | |
{ | |
cancellationToken.ThrowIfCancellationRequested(); | |
await this.Client.Credentials.ProcessHttpRequestAsync(httpRequest, cancellationToken).ConfigureAwait(false); | |
} | |
// Send Request | |
if (shouldTrace) | |
{ | |
ServiceClientTracing.SendRequest(invocationId, httpRequest); | |
} | |
cancellationToken.ThrowIfCancellationRequested(); | |
HttpResponseMessage httpResponse = await this.Client.HttpClient.SendAsync(httpRequest, cancellationToken).ConfigureAwait(false); | |
if (shouldTrace) | |
{ | |
ServiceClientTracing.ReceiveResponse(invocationId, httpResponse); | |
} | |
HttpStatusCode statusCode = httpResponse.StatusCode; | |
cancellationToken.ThrowIfCancellationRequested(); | |
if (!(statusCode == (HttpStatusCode)Enum.Parse(typeof(HttpStatusCode), "OK") || statusCode == (HttpStatusCode)Enum.Parse(typeof(HttpStatusCode), "BadRequest") || statusCode == (HttpStatusCode)Enum.Parse(typeof(HttpStatusCode), "Unauthorized"))) | |
{ | |
var ex = new HttpOperationException(string.Format("Operation returned an invalid status code '{0}'", statusCode)); | |
ex.Request = httpRequest; | |
ex.Response = httpResponse; | |
if (shouldTrace) | |
{ | |
ServiceClientTracing.Error(invocationId, ex); | |
} | |
throw ex; | |
} | |
// Create Result | |
var result = new HttpOperationResponse<IList<Action>>(); | |
result.Request = httpRequest; | |
result.Response = httpResponse; | |
// Deserialize Response | |
if (statusCode == (HttpStatusCode)Enum.Parse(typeof(HttpStatusCode), "OK")) | |
{ | |
string responseContent = await httpResponse.Content.ReadAsStringAsync().ConfigureAwait(false); | |
result.Body = JsonConvert.DeserializeObject<IList<Action>>(responseContent, this.Client.DeserializationSettings); | |
} | |
if (shouldTrace) | |
{ | |
ServiceClientTracing.Exit(invocationId, result); | |
} | |
return result; | |
} | |
// ... | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment