using System; using System.Net.Http; using System.Threading.Tasks; using Bit.App.Abstractions; using Bit.App.Models.Api; using Plugin.Connectivity.Abstractions; using Newtonsoft.Json; using Bit.App.Utilities; namespace Bit.App.Repositories { public class AccountsApiRepository : BaseApiRepository, IAccountsApiRepository { public AccountsApiRepository( IConnectivity connectivity, IHttpService httpService, ITokenService tokenService) : base(connectivity, httpService, tokenService) { } protected override string ApiRoute => "accounts"; public virtual async Task PostRegisterAsync(RegisterRequest requestObj) { if(!Connectivity.IsConnected) { return HandledNotConnected(); } using(var client = HttpService.ApiClient) { var requestMessage = new TokenHttpRequestMessage(requestObj) { Method = HttpMethod.Post, RequestUri = new Uri(string.Concat(client.BaseAddress, ApiRoute, "/register")), }; try { var response = await client.SendAsync(requestMessage).ConfigureAwait(false); if(!response.IsSuccessStatusCode) { return await HandleErrorAsync(response).ConfigureAwait(false); } return ApiResult.Success(response.StatusCode); } catch { return HandledWebException(); } } } public virtual async Task PostPasswordHintAsync(PasswordHintRequest requestObj) { if(!Connectivity.IsConnected) { return HandledNotConnected(); } using(var client = HttpService.ApiClient) { var requestMessage = new TokenHttpRequestMessage(requestObj) { Method = HttpMethod.Post, RequestUri = new Uri(string.Concat(client.BaseAddress, ApiRoute, "/password-hint")), }; try { var response = await client.SendAsync(requestMessage).ConfigureAwait(false); if(!response.IsSuccessStatusCode) { return await HandleErrorAsync(response).ConfigureAwait(false); } return ApiResult.Success(response.StatusCode); } catch { return HandledWebException(); } } } public virtual async Task> GetAccountRevisionDateAsync() { if(!Connectivity.IsConnected) { return HandledNotConnected(); } var tokenStateResponse = await HandleTokenStateAsync(); if(!tokenStateResponse.Succeeded) { return tokenStateResponse; } using(var client = HttpService.ApiClient) { var requestMessage = new TokenHttpRequestMessage() { Method = HttpMethod.Get, RequestUri = new Uri(string.Concat(client.BaseAddress, ApiRoute, "/revision-date")), }; try { var response = await client.SendAsync(requestMessage).ConfigureAwait(false); if(!response.IsSuccessStatusCode) { return await HandleErrorAsync(response).ConfigureAwait(false); } var responseContent = await response.Content.ReadAsStringAsync().ConfigureAwait(false); if(responseContent.Contains("null")) { return ApiResult.Success(null, response.StatusCode); } long ms; if(!long.TryParse(responseContent, out ms)) { return await HandleErrorAsync(response).ConfigureAwait(false); } return ApiResult.Success(Helpers.Epoc.AddMilliseconds(ms), response.StatusCode); } catch { return HandledWebException(); } } } public virtual async Task> GetProfileAsync() { if(!Connectivity.IsConnected) { return HandledNotConnected(); } var tokenStateResponse = await HandleTokenStateAsync(); if(!tokenStateResponse.Succeeded) { return tokenStateResponse; } using(var client = HttpService.ApiClient) { var requestMessage = new TokenHttpRequestMessage() { Method = HttpMethod.Get, RequestUri = new Uri(string.Concat(client.BaseAddress, ApiRoute, "/profile")), }; try { var response = await client.SendAsync(requestMessage).ConfigureAwait(false); if(!response.IsSuccessStatusCode) { return await HandleErrorAsync(response).ConfigureAwait(false); } var responseContent = await response.Content.ReadAsStringAsync().ConfigureAwait(false); var responseObj = JsonConvert.DeserializeObject(responseContent); return ApiResult.Success(responseObj, response.StatusCode); } catch { return HandledWebException(); } } } } }