using System; using System.Net.Http; using System.Threading.Tasks; using Bit.App.Abstractions; using Bit.App.Models.Api; using Newtonsoft.Json; using Plugin.Connectivity.Abstractions; namespace Bit.App.Repositories { public class AuthApiRepository : BaseApiRepository, IAuthApiRepository { public AuthApiRepository(IConnectivity connectivity) : base(connectivity) { } protected override string ApiRoute => "auth"; public virtual async Task> PostTokenAsync(TokenRequest requestObj) { if(!Connectivity.IsConnected) { return HandledNotConnected(); } using(var client = new ApiHttpClient()) { var requestMessage = new TokenHttpRequestMessage(requestObj) { Method = HttpMethod.Post, RequestUri = new Uri(client.BaseAddress, string.Concat(ApiRoute, "/token")), }; var response = await client.SendAsync(requestMessage); if(!response.IsSuccessStatusCode) { return await HandleErrorAsync(response); } var responseContent = await response.Content.ReadAsStringAsync(); var responseObj = JsonConvert.DeserializeObject(responseContent); return ApiResult.Success(responseObj, response.StatusCode); } } public virtual async Task> PostTokenTwoFactorAsync(TokenTwoFactorRequest requestObj) { if(!Connectivity.IsConnected) { return HandledNotConnected(); } using(var client = new ApiHttpClient()) { var requestMessage = new TokenHttpRequestMessage(requestObj) { Method = HttpMethod.Post, RequestUri = new Uri(client.BaseAddress, string.Concat(ApiRoute, "/token/two-factor")), }; var response = await client.SendAsync(requestMessage); if(!response.IsSuccessStatusCode) { return await HandleErrorAsync(response); } var responseContent = await response.Content.ReadAsStringAsync(); var responseObj = JsonConvert.DeserializeObject(responseContent); return ApiResult.Success(responseObj, response.StatusCode); } } } }