You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In a project I am currently working on, we must send additional request parameters in the OIDC Token Exchange grant request. I want a simpler way to add and define additional parameters to be sent with the token exchange grant request.
does not allow customization to this level. What is possible, is adding a static list of additional parameters to the grant request by passing a customized contextAttributesMapper to the
To be more specific, when calling OAuth2AuthorizedClientManager::authorize, which will perform a token exchange for this client registration, the request must in my case include an additional parameter to be sent.
This is not possible without completely replacing the implementation of TokenExchangeOAuth2AuthorizedClientProvider for the following reasons:
The parametersConverter of the RestClientTokenExchangeTokenResponseClient only has access to the TokenExchangeGrantRequest as an input that might contain per-exchange dynamic parameters.
None of the attributes set in the OAuth2AuthorizeRequest passed to OAuth2AuthorizedClientManager::authorize end up in the TokenExchangeGrantRequest object.
And even if that were the case, a second call to authorize the client with a different dynamic parameter would not result in another token exchange, as the context thinks the client is already authorized because of this snippet in TokenExchangeOAuth2AuthorizedClientProvider:
if (authorizedClient != null && !hasTokenExpired(authorizedClient.getAccessToken())) {
// If client is already authorized but access token is NOT expired than no
// need for re-authorization
returnnull;
}
I was able to circumvent these short-comings by:
Extending OAuth2AuthorizedClient by adding an additional field for the additional attributes.
Copying TokenExchangeOAuth2AuthorizedClientProvider and extending the check for re-authorization using the new field from OAuth2AuthorizedClient.
Using a CustomTokenExchangeGrantRequest that extends TokenExchangeGrantRequest and includes my dynamic parameters for the request.
Using a parametersConverter that casts the TokenExchangeGrantRequest to a CustomTokenExchangeGrantRequest and sets the additional parameters`
Adding the additional attributes to the OAuth2AuthorizationContext.attributes() to compare them to the last request in the next authorize(...) call.
Extending the check for re-authorizization and non-expired token by comparing the additional parameters with the last ones.
Yes, this explanation is probably not easy to follow, so I am willing to create a PR that would support my use case in a slightly generalized way for every one to use.
I expect the change to be simpler than what I described above, as my complications mainly arose from the fact that TokenExchangeOAuth2AuthorizedClientProvider is a final class.
The text was updated successfully, but these errors were encountered:
Upon implementing a PR to see if my proposed feature can be implemented without too many changes, I realized that my current workaround does not even work as I thought it did.
The custom extended OAuth2AuthorizedClient stored in the context does not retain the additional new fields. I incorrectly assumed that this object would be stored as-is, but it is recreated at a later stage in
Expected Behavior
In a project I am currently working on, we must send additional request parameters in the OIDC Token Exchange grant request. I want a simpler way to add and define additional parameters to be sent with the token exchange grant request.
Current Behavior
The current implementation of
spring-security/oauth2/oauth2-client/src/main/java/org/springframework/security/oauth2/client/TokenExchangeOAuth2AuthorizedClientProvider.java
Line 44 in 0e3cfd1
contextAttributesMapper
to thespring-security/oauth2/oauth2-client/src/main/java/org/springframework/security/oauth2/client/web/DefaultOAuth2AuthorizedClientManager.java
Line 88 in 0e3cfd1
Context
To be more specific, when calling
OAuth2AuthorizedClientManager::authorize
, which will perform a token exchange for this client registration, the request must in my case include an additional parameter to be sent.This is not possible without completely replacing the implementation of
TokenExchangeOAuth2AuthorizedClientProvider
for the following reasons:parametersConverter
of theRestClientTokenExchangeTokenResponseClient
only has access to theTokenExchangeGrantRequest
as an input that might contain per-exchange dynamic parameters.OAuth2AuthorizeRequest
passed toOAuth2AuthorizedClientManager::authorize
end up in theTokenExchangeGrantRequest
object.TokenExchangeOAuth2AuthorizedClientProvider
:spring-security/oauth2/oauth2-client/src/main/java/org/springframework/security/oauth2/client/TokenExchangeOAuth2AuthorizedClientProvider.java
Lines 76 to 81 in 0e3cfd1
I was able to circumvent these short-comings by:
OAuth2AuthorizedClient
by adding an additional field for the additional attributes.TokenExchangeOAuth2AuthorizedClientProvider
and extending the check for re-authorization using the new field fromOAuth2AuthorizedClient
.CustomTokenExchangeGrantRequest
that extendsTokenExchangeGrantRequest
and includes my dynamic parameters for the request.parametersConverter
that casts theTokenExchangeGrantRequest
to aCustomTokenExchangeGrantRequest
and sets the additional parameters`OAuth2AuthorizationContext.attributes()
to compare them to the last request in the nextauthorize(...)
call.Yes, this explanation is probably not easy to follow, so I am willing to create a PR that would support my use case in a slightly generalized way for every one to use.
I expect the change to be simpler than what I described above, as my complications mainly arose from the fact that
TokenExchangeOAuth2AuthorizedClientProvider
is a final class.The text was updated successfully, but these errors were encountered: