diff options
Diffstat (limited to 'dsa/FireBase/Query/FirebaseQuery.cs')
-rw-r--r-- | dsa/FireBase/Query/FirebaseQuery.cs | 99 |
1 files changed, 33 insertions, 66 deletions
diff --git a/dsa/FireBase/Query/FirebaseQuery.cs b/dsa/FireBase/Query/FirebaseQuery.cs index 60d0289..91e7afa 100644 --- a/dsa/FireBase/Query/FirebaseQuery.cs +++ b/dsa/FireBase/Query/FirebaseQuery.cs @@ -8,13 +8,11 @@ using Firebase.Database.Http; using Firebase.Database.Streaming; using Newtonsoft.Json; -namespace Firebase.Database.Query -{ +namespace Firebase.Database.Query { /// <summary> /// Represents a firebase query. /// </summary> - public abstract class FirebaseQuery : IFirebaseQuery, IDisposable - { + public abstract class FirebaseQuery : IFirebaseQuery, IDisposable { protected readonly FirebaseQuery Parent; private HttpClient client; @@ -25,8 +23,7 @@ namespace Firebase.Database.Query /// </summary> /// <param name="parent"> The parent of this query. </param> /// <param name="client"> The owning client. </param> - protected FirebaseQuery(FirebaseQuery parent, FirebaseClient client) - { + protected FirebaseQuery(FirebaseQuery parent, FirebaseClient client) { Client = client; Parent = parent; } @@ -34,8 +31,7 @@ namespace Firebase.Database.Query /// <summary> /// Disposes this instance. /// </summary> - public void Dispose() - { + public void Dispose() { client?.Dispose(); } @@ -50,16 +46,13 @@ namespace Firebase.Database.Query /// <param name="timeout"> Optional timeout value. </param> /// <typeparam name="T"> Type of elements. </typeparam> /// <returns> Collection of <see cref="FirebaseObject{T}" /> holding the entities returned by server. </returns> - public async Task<IReadOnlyCollection<FirebaseObject<T>>> OnceAsync<T>(TimeSpan? timeout = null) - { + public async Task<IReadOnlyCollection<FirebaseObject<T>>> OnceAsync<T>(TimeSpan? timeout = null) { var url = string.Empty; - try - { + try { url = await BuildUrlAsync().ConfigureAwait(false); } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException("Couldn't build the url", string.Empty, string.Empty, HttpStatusCode.OK, ex); } @@ -75,10 +68,8 @@ namespace Firebase.Database.Query /// <param name="elementRoot"> Optional custom root element of received json items. </param> /// <returns> Observable stream of <see cref="FirebaseEvent{T}" />. </returns> public IObservable<FirebaseEvent<T>> AsObservable<T>( - EventHandler<ExceptionEventArgs<FirebaseException>> exceptionHandler = null, string elementRoot = "") - { - return Observable.Create<FirebaseEvent<T>>(observer => - { + EventHandler<ExceptionEventArgs<FirebaseException>> exceptionHandler = null, string elementRoot = "") { + return Observable.Create<FirebaseEvent<T>>(observer => { var sub = new FirebaseSubscription<T>(observer, this, elementRoot, new FirebaseCache<T>()); sub.ExceptionThrown += exceptionHandler; return sub.Run(); @@ -89,11 +80,9 @@ namespace Firebase.Database.Query /// Builds the actual URL of this query. /// </summary> /// <returns> The <see cref="string" />. </returns> - public async Task<string> BuildUrlAsync() - { + public async Task<string> BuildUrlAsync() { // if token factory is present on the parent then use it to generate auth token - if (Client.Options.AuthTokenAsyncFactory != null) - { + if (Client.Options.AuthTokenAsyncFactory != null) { var token = await Client.Options.AuthTokenAsyncFactory().ConfigureAwait(false); return this.WithAuth(token).BuildUrl(null); } @@ -124,23 +113,19 @@ namespace Firebase.Database.Query /// <param name="timeout"> Optional timeout value. </param> /// <typeparam name="T"> Type of elements. </typeparam> /// <returns> Single object of type <typeparamref name="T" />. </returns> - public async Task<T> OnceSingleAsync<T>(TimeSpan? timeout = null) - { + public async Task<T> OnceSingleAsync<T>(TimeSpan? timeout = null) { var responseData = string.Empty; var statusCode = HttpStatusCode.OK; var url = string.Empty; - try - { + try { url = await BuildUrlAsync().ConfigureAwait(false); } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException("Couldn't build the url", string.Empty, responseData, statusCode, ex); } - try - { + try { var response = await GetClient(timeout).GetAsync(url).ConfigureAwait(false); statusCode = response.StatusCode; responseData = await response.Content.ReadAsStringAsync().ConfigureAwait(false); @@ -150,8 +135,7 @@ namespace Firebase.Database.Query return JsonConvert.DeserializeObject<T>(responseData, Client.Options.JsonSerializerSettings); } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException(url, string.Empty, responseData, statusCode, ex); } } @@ -165,11 +149,9 @@ namespace Firebase.Database.Query /// <typeparam name="T"> Type of <see cref="obj" /> </typeparam> /// <returns> Resulting firebase object with populated key. </returns> public async Task<FirebaseObject<string>> PostAsync(string data, bool generateKeyOffline = true, - TimeSpan? timeout = null) - { + TimeSpan? timeout = null) { // post generates a new key server-side, while put can be used with an already generated local key - if (generateKeyOffline) - { + if (generateKeyOffline) { var key = FirebaseKeyGenerator.Next(); await new ChildQuery(this, () => key, Client).PutAsync(data).ConfigureAwait(false); @@ -190,8 +172,7 @@ namespace Firebase.Database.Query /// <param name="timeout"> Optional timeout value. </param> /// <typeparam name="T"> Type of <see cref="obj" /> </typeparam> /// <returns> The <see cref="Task" />. </returns> - public async Task PatchAsync(string data, TimeSpan? timeout = null) - { + public async Task PatchAsync(string data, TimeSpan? timeout = null) { var c = GetClient(timeout); await this.Silent().SendAsync(c, data, new HttpMethod("PATCH")).ConfigureAwait(false); @@ -204,8 +185,7 @@ namespace Firebase.Database.Query /// <param name="timeout"> Optional timeout value. </param> /// <typeparam name="T"> Type of <see cref="obj" /> </typeparam> /// <returns> The <see cref="Task" />. </returns> - public async Task PutAsync(string data, TimeSpan? timeout = null) - { + public async Task PutAsync(string data, TimeSpan? timeout = null) { var c = GetClient(timeout); await this.Silent().SendAsync(c, data, HttpMethod.Put).ConfigureAwait(false); @@ -216,32 +196,27 @@ namespace Firebase.Database.Query /// </summary> /// <param name="timeout"> Optional timeout value. </param> /// <returns> The <see cref="Task" />. </returns> - public async Task DeleteAsync(TimeSpan? timeout = null) - { + public async Task DeleteAsync(TimeSpan? timeout = null) { var c = GetClient(timeout); var url = string.Empty; var responseData = string.Empty; var statusCode = HttpStatusCode.OK; - try - { + try { url = await BuildUrlAsync().ConfigureAwait(false); } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException("Couldn't build the url", string.Empty, responseData, statusCode, ex); } - try - { + try { var result = await c.DeleteAsync(url).ConfigureAwait(false); statusCode = result.StatusCode; responseData = await result.Content.ReadAsStringAsync().ConfigureAwait(false); result.EnsureSuccessStatusCode(); } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException(url, string.Empty, responseData, statusCode, ex); } } @@ -253,8 +228,7 @@ namespace Firebase.Database.Query /// <returns> The <see cref="string" />. </returns> protected abstract string BuildUrlSegment(FirebaseQuery child); - private string BuildUrl(FirebaseQuery child) - { + private string BuildUrl(FirebaseQuery child) { var url = BuildUrlSegment(child); if (Parent != null) url = Parent.BuildUrl(this) + url; @@ -262,8 +236,7 @@ namespace Firebase.Database.Query return url; } - private HttpClient GetClient(TimeSpan? timeout = null) - { + private HttpClient GetClient(TimeSpan? timeout = null) { if (client == null) client = new HttpClient(); if (!timeout.HasValue) @@ -274,29 +247,24 @@ namespace Firebase.Database.Query return client; } - private async Task<string> SendAsync(HttpClient client, string data, HttpMethod method) - { + private async Task<string> SendAsync(HttpClient client, string data, HttpMethod method) { var responseData = string.Empty; var statusCode = HttpStatusCode.OK; var requestData = data; var url = string.Empty; - try - { + try { url = await BuildUrlAsync().ConfigureAwait(false); } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException("Couldn't build the url", requestData, responseData, statusCode, ex); } - var message = new HttpRequestMessage(method, url) - { + var message = new HttpRequestMessage(method, url) { Content = new StringContent(requestData) }; - try - { + try { var result = await client.SendAsync(message).ConfigureAwait(false); statusCode = result.StatusCode; responseData = await result.Content.ReadAsStringAsync().ConfigureAwait(false); @@ -305,8 +273,7 @@ namespace Firebase.Database.Query return responseData; } - catch (Exception ex) - { + catch (Exception ex) { throw new FirebaseException(url, requestData, responseData, statusCode, ex); } } |