using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Net.Http.Json;
using System.Threading.Tasks;
using Microsoft.Extensions.Configuration;
using Volo.Abp;
namespace Win_in.Sfs.Wms.Pda.Authenticaitons;
///
///
///
public class TokenService : ITokenService
{
private readonly IConfiguration _configuration;
///
///
///
///
public TokenService(IConfiguration configuration)
{
_configuration = configuration;
}
///
///
///
///
///
///
public virtual async Task GetTokenAsync(string username, string password)
{
const string routeString = "connect/token";
var baseUrl = _configuration["IdentityClients:Default:Authority"];
var client_id = _configuration["IdentityClients:Default:ClientId"];
var client_secret = _configuration["IdentityClients:Default:ClientSecret"];
var grant_type = "password";
var client = new HttpClient();
client.BaseAddress = new Uri(baseUrl);
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
var content = new FormUrlEncodedContent(new[]
{
new KeyValuePair("client_id",client_id),
new KeyValuePair("client_secret",client_secret),
new KeyValuePair("grant_type",grant_type),
new KeyValuePair("username",username),
new KeyValuePair("password",password),
});
var response = await client.PostAsync(routeString, content).ConfigureAwait(false);
Console.WriteLine(response.RequestMessage.RequestUri);
if (!response.IsSuccessStatusCode)
{
var str = await response.Content.ReadAsStringAsync().ConfigureAwait(false);
throw new UserFriendlyException(str);
}
var dto = await response.Content.ReadFromJsonAsync().ConfigureAwait(false);
return dto;
}
}