/// <summary> /// Sends a token request using the password grant type. /// </summary> /// <param name="client">The client.</param> /// <param name="request">The request.</param> /// <param name="cancellationToken">The cancellation token.</param> /// <returns></returns> public static async Task <IdentityModel.Client.IdentityModelExtensions.TokenResponse> RequestPasswordTokenAsync(this HttpMessageInvoker client, PasswordTokenRequest request, CancellationToken?cancellationToken = null) { var clone = request.Clone(); clone.Parameters.AddRequired(OidcConstants.TokenRequest.GrantType, OidcConstants.GrantTypes.Password); clone.Parameters.AddRequired(OidcConstants.TokenRequest.UserName, request.UserName); clone.Parameters.AddRequired(OidcConstants.TokenRequest.Password, request.Password, allowEmpty: true); clone.Parameters.AddOptional(OidcConstants.TokenRequest.Scope, request.Scope); return(await client.RequestTokenAsync(clone, cancellationToken).ConfigureAwait(false)); }
/// <summary> /// Sends a token request using the password grant type. /// </summary> /// <param name="client">The client.</param> /// <param name="request">The request.</param> /// <param name="cancellationToken">The cancellation token.</param> /// <returns></returns> public static async Task <TokenResponse> RequestPasswordTokenAsync(this HttpClient client, PasswordTokenRequest request, CancellationToken cancellationToken = default) { request.GrantType = OidcConstants.GrantTypes.Password; request.Parameters.AddRequired(OidcConstants.TokenRequest.UserName, request.UserName); request.Parameters.AddRequired(OidcConstants.TokenRequest.Password, request.Password, allowEmpty: true); request.Parameters.AddOptional(OidcConstants.TokenRequest.Scope, request.Scope); return(await client.RequestTokenAsync(request, cancellationToken)); }
/// <summary> /// Sends a token request using the password grant type. /// </summary> /// <param name="client">The client.</param> /// <param name="request">The request.</param> /// <param name="cancellationToken">The cancellation token.</param> /// <returns></returns> public static async Task <TokenResponse> RequestPasswordTokenAsync(this HttpMessageInvoker client, PasswordTokenRequest request, CancellationToken cancellationToken = default) { var clone = request.Clone(); clone.Parameters.AddRequired(OidcConstants.TokenRequest.GrantType, OidcConstants.GrantTypes.Password); clone.Parameters.AddRequired(OidcConstants.TokenRequest.UserName, request.UserName); clone.Parameters.AddRequired(OidcConstants.TokenRequest.Password, request.Password, allowEmptyValue: true); clone.Parameters.AddOptional(OidcConstants.TokenRequest.Scope, request.Scope); foreach (var resource in request.Resource) { clone.Parameters.AddRequired(OidcConstants.TokenRequest.Resource, resource, allowDuplicates: true); } return(await client.RequestTokenAsync(clone, cancellationToken).ConfigureAwait()); }
public static async Task <TokenResponse> RequestPasswordTokenAsync(this HttpMessageInvoker client, PasswordTokenRequest request, CancellationToken?cancellationToken = null) { Request request1 = request.Clone(); request1.Parameters.AddRequired("grant_type", "password", false); request1.Parameters.AddRequired("username", request.UserName, false); request1.Parameters.AddRequired("password", request.Password, true); request1.Parameters.AddOptional("scope", request.Scope); ConfiguredTaskAwaitable <TokenResponse> configuredTaskAwaitable = HttpClientTokenRequestExtensions.RequestTokenAsync(client, request1, cancellationToken).ConfigureAwait(false); return(await configuredTaskAwaitable); }