6 changed files with 147 additions and 206 deletions
@ -1,96 +0,0 @@ |
|||||||
/* |
|
||||||
* Copyright 2020-2023 the original author or authors. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* https://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
*/ |
|
||||||
package sample.dcr; |
|
||||||
|
|
||||||
import com.nimbusds.jose.jwk.JWKSet; |
|
||||||
import com.nimbusds.jose.jwk.RSAKey; |
|
||||||
import com.nimbusds.jose.jwk.source.ImmutableJWKSet; |
|
||||||
import com.nimbusds.jose.jwk.source.JWKSource; |
|
||||||
import com.nimbusds.jose.proc.SecurityContext; |
|
||||||
import org.springframework.context.annotation.Bean; |
|
||||||
import org.springframework.context.annotation.Configuration; |
|
||||||
import org.springframework.security.config.Customizer; |
|
||||||
import org.springframework.security.config.annotation.web.builders.HttpSecurity; |
|
||||||
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; |
|
||||||
import org.springframework.security.core.userdetails.UserDetailsService; |
|
||||||
import org.springframework.security.oauth2.jwt.JwtDecoder; |
|
||||||
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.AuthorizationServerSettings; |
|
||||||
import org.springframework.security.provisioning.InMemoryUserDetailsManager; |
|
||||||
import org.springframework.security.web.SecurityFilterChain; |
|
||||||
|
|
||||||
import java.security.KeyPair; |
|
||||||
import java.security.KeyPairGenerator; |
|
||||||
import java.security.interfaces.RSAPrivateKey; |
|
||||||
import java.security.interfaces.RSAPublicKey; |
|
||||||
import java.util.Collections; |
|
||||||
import java.util.UUID; |
|
||||||
|
|
||||||
@Configuration |
|
||||||
@EnableWebSecurity |
|
||||||
public class DcrConfiguration { |
|
||||||
@Bean // <1>
|
|
||||||
public SecurityFilterChain authorizationServerSecurityFilterChain(HttpSecurity http) throws Exception { |
|
||||||
OAuth2AuthorizationServerConfiguration.applyDefaultSecurity(http); |
|
||||||
http.getConfigurer(OAuth2AuthorizationServerConfigurer.class) |
|
||||||
.oidc(oidc -> oidc.clientRegistrationEndpoint(Customizer.withDefaults())); // <2>
|
|
||||||
http.oauth2ResourceServer(oauth2ResourceServer -> |
|
||||||
oauth2ResourceServer.jwt(Customizer.withDefaults())); |
|
||||||
|
|
||||||
return http.build(); |
|
||||||
} |
|
||||||
// @fold:on
|
|
||||||
|
|
||||||
@Bean |
|
||||||
public UserDetailsService userDetailsService() { |
|
||||||
// This example uses client credentials grant type - no need for any users.
|
|
||||||
return new InMemoryUserDetailsManager(Collections.emptyList()); |
|
||||||
} |
|
||||||
|
|
||||||
@Bean |
|
||||||
public JWKSource<SecurityContext> jwkSource() { |
|
||||||
// @formatter:off
|
|
||||||
KeyPair keyPair; |
|
||||||
try { |
|
||||||
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA"); |
|
||||||
keyPairGenerator.initialize(2048); |
|
||||||
keyPair = keyPairGenerator.generateKeyPair(); |
|
||||||
} catch (Exception ex) { |
|
||||||
throw new IllegalStateException(ex); |
|
||||||
} |
|
||||||
RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic(); |
|
||||||
RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate(); |
|
||||||
RSAKey rsaKey = new RSAKey.Builder(publicKey) |
|
||||||
.privateKey(privateKey) |
|
||||||
.keyID(UUID.randomUUID().toString()) |
|
||||||
.build(); |
|
||||||
// @formatter:on
|
|
||||||
JWKSet jwkSet = new JWKSet(rsaKey); |
|
||||||
return new ImmutableJWKSet<>(jwkSet); |
|
||||||
} |
|
||||||
|
|
||||||
@Bean |
|
||||||
public JwtDecoder jwtDecoder(JWKSource<SecurityContext> jwkSource) { |
|
||||||
return OAuth2AuthorizationServerConfiguration.jwtDecoder(jwkSource); |
|
||||||
} |
|
||||||
|
|
||||||
@Bean |
|
||||||
public AuthorizationServerSettings authorizationServerSettings() { |
|
||||||
return AuthorizationServerSettings.builder().build(); |
|
||||||
} |
|
||||||
// @fold:off
|
|
||||||
} |
|
||||||
@ -0,0 +1,42 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2020-2023 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
package sample.registration; |
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean; |
||||||
|
import org.springframework.context.annotation.Configuration; |
||||||
|
import org.springframework.security.config.Customizer; |
||||||
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity; |
||||||
|
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; |
||||||
|
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.web.SecurityFilterChain; |
||||||
|
|
||||||
|
@Configuration |
||||||
|
@EnableWebSecurity |
||||||
|
public class SecurityConfig { |
||||||
|
|
||||||
|
@Bean |
||||||
|
public SecurityFilterChain authorizationServerSecurityFilterChain(HttpSecurity http) throws Exception { |
||||||
|
OAuth2AuthorizationServerConfiguration.applyDefaultSecurity(http); |
||||||
|
http.getConfigurer(OAuth2AuthorizationServerConfigurer.class) |
||||||
|
.oidc(oidc -> oidc.clientRegistrationEndpoint(Customizer.withDefaults())); // <1>
|
||||||
|
http.oauth2ResourceServer(oauth2ResourceServer -> |
||||||
|
oauth2ResourceServer.jwt(Customizer.withDefaults())); |
||||||
|
|
||||||
|
return http.build(); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
Loading…
Reference in new issue