|
@@ -28,14 +28,17 @@ import org.springframework.context.annotation.Configuration;
|
|
|
import org.springframework.core.Ordered;
|
|
|
import org.springframework.core.annotation.Order;
|
|
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
|
|
+import org.springframework.security.config.annotation.web.configurers.oauth2.server.resource.OAuth2ResourceServerConfigurer;
|
|
|
import org.springframework.security.oauth2.core.AuthorizationGrantType;
|
|
|
import org.springframework.security.oauth2.core.ClientAuthenticationMethod;
|
|
|
import org.springframework.security.oauth2.core.oidc.OidcScopes;
|
|
|
+import org.springframework.security.oauth2.jwt.JwtDecoder;
|
|
|
import org.springframework.security.oauth2.server.authorization.InMemoryOAuth2AuthorizationConsentService;
|
|
|
import org.springframework.security.oauth2.server.authorization.OAuth2AuthorizationConsentService;
|
|
|
import org.springframework.security.oauth2.server.authorization.client.InMemoryRegisteredClientRepository;
|
|
|
import org.springframework.security.oauth2.server.authorization.client.RegisteredClient;
|
|
|
import org.springframework.security.oauth2.server.authorization.client.RegisteredClientRepository;
|
|
|
+import org.springframework.security.oauth2.server.authorization.config.annotation.web.configuration.OAuth2AuthorizationServerConfiguration;
|
|
|
import org.springframework.security.oauth2.server.authorization.config.annotation.web.configurers.OAuth2AuthorizationServerConfigurer;
|
|
|
import org.springframework.security.oauth2.server.authorization.settings.ClientSettings;
|
|
|
import org.springframework.security.oauth2.server.authorization.settings.ProviderSettings;
|
|
@@ -72,6 +75,7 @@ public class AuthorizationServerConfig {
|
|
|
.exceptionHandling(exceptions ->
|
|
|
exceptions.authenticationEntryPoint(new LoginUrlAuthenticationEntryPoint("/login"))
|
|
|
)
|
|
|
+ .oauth2ResourceServer(OAuth2ResourceServerConfigurer::jwt)
|
|
|
.apply(authorizationServerConfigurer);
|
|
|
return http.build();
|
|
|
}
|
|
@@ -89,6 +93,7 @@ public class AuthorizationServerConfig {
|
|
|
.redirectUri("http://127.0.0.1:8080/login/oauth2/code/messaging-client-oidc")
|
|
|
.redirectUri("http://127.0.0.1:8080/authorized")
|
|
|
.scope(OidcScopes.OPENID)
|
|
|
+ .scope(OidcScopes.PROFILE)
|
|
|
.scope("message.read")
|
|
|
.scope("message.write")
|
|
|
.clientSettings(ClientSettings.builder().requireAuthorizationConsent(true).build())
|
|
@@ -104,6 +109,11 @@ public class AuthorizationServerConfig {
|
|
|
return (jwkSelector, securityContext) -> jwkSelector.select(jwkSet);
|
|
|
}
|
|
|
|
|
|
+ @Bean
|
|
|
+ public JwtDecoder jwtDecoder(JWKSource<SecurityContext> jwkSource) {
|
|
|
+ return OAuth2AuthorizationServerConfiguration.jwtDecoder(jwkSource);
|
|
|
+ }
|
|
|
+
|
|
|
@Bean
|
|
|
public ProviderSettings providerSettings() {
|
|
|
return ProviderSettings.builder().issuer("http://localhost:9000").build();
|