mirror of
https://github.com/spring-projects/spring-security.git
synced 2025-06-26 05:42:31 +00:00
Merge branch '6.2.x' into 6.3.x
Closes gh-15410
This commit is contained in:
commit
8ee497f4c5
@ -16,6 +16,11 @@
|
|||||||
|
|
||||||
package org.springframework.security.config.annotation.web.configurers.oauth2.client;
|
package org.springframework.security.config.annotation.web.configurers.oauth2.client;
|
||||||
|
|
||||||
|
import com.nimbusds.jose.JOSEObjectType;
|
||||||
|
import com.nimbusds.jose.proc.DefaultJOSEObjectTypeVerifier;
|
||||||
|
import com.nimbusds.jose.proc.JOSEObjectTypeVerifier;
|
||||||
|
import com.nimbusds.jose.proc.SecurityContext;
|
||||||
|
|
||||||
import org.springframework.security.authentication.AuthenticationProvider;
|
import org.springframework.security.authentication.AuthenticationProvider;
|
||||||
import org.springframework.security.authentication.AuthenticationServiceException;
|
import org.springframework.security.authentication.AuthenticationServiceException;
|
||||||
import org.springframework.security.core.Authentication;
|
import org.springframework.security.core.Authentication;
|
||||||
@ -26,11 +31,14 @@ import org.springframework.security.oauth2.client.registration.ClientRegistratio
|
|||||||
import org.springframework.security.oauth2.core.OAuth2AuthenticationException;
|
import org.springframework.security.oauth2.core.OAuth2AuthenticationException;
|
||||||
import org.springframework.security.oauth2.core.OAuth2Error;
|
import org.springframework.security.oauth2.core.OAuth2Error;
|
||||||
import org.springframework.security.oauth2.core.OAuth2ErrorCodes;
|
import org.springframework.security.oauth2.core.OAuth2ErrorCodes;
|
||||||
|
import org.springframework.security.oauth2.core.converter.ClaimTypeConverter;
|
||||||
import org.springframework.security.oauth2.jwt.BadJwtException;
|
import org.springframework.security.oauth2.jwt.BadJwtException;
|
||||||
import org.springframework.security.oauth2.jwt.Jwt;
|
import org.springframework.security.oauth2.jwt.Jwt;
|
||||||
import org.springframework.security.oauth2.jwt.JwtDecoder;
|
import org.springframework.security.oauth2.jwt.JwtDecoder;
|
||||||
import org.springframework.security.oauth2.jwt.JwtDecoderFactory;
|
import org.springframework.security.oauth2.jwt.JwtDecoderFactory;
|
||||||
|
import org.springframework.security.oauth2.jwt.NimbusJwtDecoder;
|
||||||
import org.springframework.util.Assert;
|
import org.springframework.util.Assert;
|
||||||
|
import org.springframework.util.StringUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An {@link AuthenticationProvider} that authenticates an OIDC Logout Token; namely
|
* An {@link AuthenticationProvider} that authenticates an OIDC Logout Token; namely
|
||||||
@ -56,9 +64,27 @@ final class OidcBackChannelLogoutAuthenticationProvider implements Authenticatio
|
|||||||
* Construct an {@link OidcBackChannelLogoutAuthenticationProvider}
|
* Construct an {@link OidcBackChannelLogoutAuthenticationProvider}
|
||||||
*/
|
*/
|
||||||
OidcBackChannelLogoutAuthenticationProvider() {
|
OidcBackChannelLogoutAuthenticationProvider() {
|
||||||
OidcIdTokenDecoderFactory logoutTokenDecoderFactory = new OidcIdTokenDecoderFactory();
|
DefaultOidcLogoutTokenValidatorFactory jwtValidator = new DefaultOidcLogoutTokenValidatorFactory();
|
||||||
logoutTokenDecoderFactory.setJwtValidatorFactory(new DefaultOidcLogoutTokenValidatorFactory());
|
this.logoutTokenDecoderFactory = (clientRegistration) -> {
|
||||||
this.logoutTokenDecoderFactory = logoutTokenDecoderFactory;
|
String jwkSetUri = clientRegistration.getProviderDetails().getJwkSetUri();
|
||||||
|
if (!StringUtils.hasText(jwkSetUri)) {
|
||||||
|
OAuth2Error oauth2Error = new OAuth2Error("missing_signature_verifier",
|
||||||
|
"Failed to find a Signature Verifier for Client Registration: '"
|
||||||
|
+ clientRegistration.getRegistrationId()
|
||||||
|
+ "'. Check to ensure you have configured the JwkSet URI.",
|
||||||
|
null);
|
||||||
|
throw new OAuth2AuthenticationException(oauth2Error, oauth2Error.toString());
|
||||||
|
}
|
||||||
|
JOSEObjectTypeVerifier<SecurityContext> typeVerifier = new DefaultJOSEObjectTypeVerifier<>(null,
|
||||||
|
JOSEObjectType.JWT, new JOSEObjectType("logout+jwt"));
|
||||||
|
NimbusJwtDecoder decoder = NimbusJwtDecoder.withJwkSetUri(jwkSetUri)
|
||||||
|
.jwtProcessorCustomizer((processor) -> processor.setJWSTypeVerifier(typeVerifier))
|
||||||
|
.build();
|
||||||
|
decoder.setJwtValidator(jwtValidator.apply(clientRegistration));
|
||||||
|
decoder.setClaimSetConverter(
|
||||||
|
new ClaimTypeConverter(OidcIdTokenDecoderFactory.createDefaultClaimTypeConverters()));
|
||||||
|
return decoder;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -73,6 +73,8 @@ import org.springframework.security.oauth2.client.registration.TestClientRegistr
|
|||||||
import org.springframework.security.oauth2.core.oidc.OidcIdToken;
|
import org.springframework.security.oauth2.core.oidc.OidcIdToken;
|
||||||
import org.springframework.security.oauth2.core.oidc.TestOidcIdTokens;
|
import org.springframework.security.oauth2.core.oidc.TestOidcIdTokens;
|
||||||
import org.springframework.security.oauth2.core.oidc.user.OidcUser;
|
import org.springframework.security.oauth2.core.oidc.user.OidcUser;
|
||||||
|
import org.springframework.security.oauth2.jose.jws.SignatureAlgorithm;
|
||||||
|
import org.springframework.security.oauth2.jwt.JwsHeader;
|
||||||
import org.springframework.security.oauth2.jwt.JwtClaimsSet;
|
import org.springframework.security.oauth2.jwt.JwtClaimsSet;
|
||||||
import org.springframework.security.oauth2.jwt.JwtEncoder;
|
import org.springframework.security.oauth2.jwt.JwtEncoder;
|
||||||
import org.springframework.security.oauth2.jwt.JwtEncoderParameters;
|
import org.springframework.security.oauth2.jwt.JwtEncoderParameters;
|
||||||
@ -513,8 +515,9 @@ public class OidcLogoutConfigurerTests {
|
|||||||
String logoutToken(@AuthenticationPrincipal OidcUser user) {
|
String logoutToken(@AuthenticationPrincipal OidcUser user) {
|
||||||
OidcLogoutToken token = TestOidcLogoutTokens.withUser(user)
|
OidcLogoutToken token = TestOidcLogoutTokens.withUser(user)
|
||||||
.audience(List.of(this.registration.getClientId())).build();
|
.audience(List.of(this.registration.getClientId())).build();
|
||||||
JwtEncoderParameters parameters = JwtEncoderParameters
|
JwsHeader header = JwsHeader.with(SignatureAlgorithm.RS256).type("logout+jwt").build();
|
||||||
.from(JwtClaimsSet.builder().claims((claims) -> claims.putAll(token.getClaims())).build());
|
JwtClaimsSet claims = JwtClaimsSet.builder().claims((c) -> c.putAll(token.getClaims())).build();
|
||||||
|
JwtEncoderParameters parameters = JwtEncoderParameters.from(header, claims);
|
||||||
return this.encoder.encode(parameters).getTokenValue();
|
return this.encoder.encode(parameters).getTokenValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -523,8 +526,9 @@ public class OidcLogoutConfigurerTests {
|
|||||||
OidcLogoutToken token = TestOidcLogoutTokens.withUser(user)
|
OidcLogoutToken token = TestOidcLogoutTokens.withUser(user)
|
||||||
.audience(List.of(this.registration.getClientId()))
|
.audience(List.of(this.registration.getClientId()))
|
||||||
.claims((claims) -> claims.remove(LogoutTokenClaimNames.SID)).build();
|
.claims((claims) -> claims.remove(LogoutTokenClaimNames.SID)).build();
|
||||||
JwtEncoderParameters parameters = JwtEncoderParameters
|
JwsHeader header = JwsHeader.with(SignatureAlgorithm.RS256).type("JWT").build();
|
||||||
.from(JwtClaimsSet.builder().claims((claims) -> claims.putAll(token.getClaims())).build());
|
JwtClaimsSet claims = JwtClaimsSet.builder().claims((c) -> c.putAll(token.getClaims())).build();
|
||||||
|
JwtEncoderParameters parameters = JwtEncoderParameters.from(header, claims);
|
||||||
return this.encoder.encode(parameters).getTokenValue();
|
return this.encoder.encode(parameters).getTokenValue();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user