2 changed files with 174 additions and 0 deletions
@ -0,0 +1,172 @@
@@ -0,0 +1,172 @@
|
||||
/* |
||||
* 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.aot.hint; |
||||
|
||||
import java.util.Arrays; |
||||
import java.util.Collections; |
||||
import java.util.HashSet; |
||||
|
||||
import org.thymeleaf.expression.Lists; |
||||
import sample.web.AuthorizationConsentController; |
||||
|
||||
import org.springframework.aot.hint.BindingReflectionHintsRegistrar; |
||||
import org.springframework.aot.hint.MemberCategory; |
||||
import org.springframework.aot.hint.RuntimeHints; |
||||
import org.springframework.aot.hint.RuntimeHintsRegistrar; |
||||
import org.springframework.aot.hint.TypeReference; |
||||
import org.springframework.security.authentication.AbstractAuthenticationToken; |
||||
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; |
||||
import org.springframework.security.core.authority.SimpleGrantedAuthority; |
||||
import org.springframework.security.core.userdetails.User; |
||||
import org.springframework.security.jackson2.CoreJackson2Module; |
||||
import org.springframework.security.oauth2.client.authentication.OAuth2AuthenticationToken; |
||||
import org.springframework.security.oauth2.client.jackson2.OAuth2ClientJackson2Module; |
||||
import org.springframework.security.oauth2.core.AbstractOAuth2Token; |
||||
import org.springframework.security.oauth2.core.AuthorizationGrantType; |
||||
import org.springframework.security.oauth2.core.endpoint.OAuth2AuthorizationRequest; |
||||
import org.springframework.security.oauth2.core.endpoint.OAuth2AuthorizationResponseType; |
||||
import org.springframework.security.oauth2.core.oidc.OidcIdToken; |
||||
import org.springframework.security.oauth2.core.oidc.OidcUserInfo; |
||||
import org.springframework.security.oauth2.core.oidc.user.DefaultOidcUser; |
||||
import org.springframework.security.oauth2.core.oidc.user.OidcUserAuthority; |
||||
import org.springframework.security.oauth2.core.user.DefaultOAuth2User; |
||||
import org.springframework.security.oauth2.core.user.OAuth2UserAuthority; |
||||
import org.springframework.security.oauth2.server.authorization.jackson2.OAuth2AuthorizationServerJackson2Module; |
||||
import org.springframework.security.oauth2.server.authorization.settings.OAuth2TokenFormat; |
||||
import org.springframework.security.web.authentication.WebAuthenticationDetails; |
||||
import org.springframework.security.web.jackson2.WebServletJackson2Module; |
||||
|
||||
/** |
||||
* {@link RuntimeHintsRegistrar} that registers {@link RuntimeHints} required for the sample. |
||||
* Statically registered via META-INF/spring/aot.factories. |
||||
* |
||||
* @author Joe Grandja |
||||
* @since 1.2 |
||||
*/ |
||||
class DemoAuthorizationServerRuntimeHints implements RuntimeHintsRegistrar { |
||||
private final BindingReflectionHintsRegistrar reflectionHintsRegistrar = new BindingReflectionHintsRegistrar(); |
||||
|
||||
@Override |
||||
public void registerHints(RuntimeHints hints, ClassLoader classLoader) { |
||||
|
||||
// Thymeleaf
|
||||
hints.reflection().registerTypes( |
||||
Arrays.asList( |
||||
TypeReference.of(AuthorizationConsentController.ScopeWithDescription.class), |
||||
TypeReference.of(Lists.class) |
||||
), builder -> |
||||
builder.withMembers(MemberCategory.DECLARED_FIELDS, |
||||
MemberCategory.INVOKE_DECLARED_CONSTRUCTORS, MemberCategory.INVOKE_DECLARED_METHODS) |
||||
); |
||||
|
||||
// Collections -> UnmodifiableSet, UnmodifiableList, UnmodifiableMap, UnmodifiableRandomAccessList, etc.
|
||||
hints.reflection().registerType( |
||||
Collections.class, MemberCategory.DECLARED_CLASSES); |
||||
|
||||
// HashSet
|
||||
hints.reflection().registerType( |
||||
HashSet.class, MemberCategory.DECLARED_FIELDS, MemberCategory.INVOKE_DECLARED_CONSTRUCTORS, |
||||
MemberCategory.INVOKE_DECLARED_METHODS); |
||||
|
||||
// Spring Security and Spring Authorization Server
|
||||
hints.reflection().registerTypes( |
||||
Arrays.asList( |
||||
TypeReference.of(AbstractAuthenticationToken.class), |
||||
TypeReference.of(WebAuthenticationDetails.class), |
||||
TypeReference.of(UsernamePasswordAuthenticationToken.class), |
||||
TypeReference.of(User.class), |
||||
TypeReference.of(OAuth2AuthenticationToken.class), |
||||
TypeReference.of(DefaultOidcUser.class), |
||||
TypeReference.of(DefaultOAuth2User.class), |
||||
TypeReference.of(OidcUserAuthority.class), |
||||
TypeReference.of(OAuth2UserAuthority.class), |
||||
TypeReference.of(SimpleGrantedAuthority.class), |
||||
TypeReference.of(OidcIdToken.class), |
||||
TypeReference.of(AbstractOAuth2Token.class), |
||||
TypeReference.of(OidcUserInfo.class), |
||||
TypeReference.of(OAuth2AuthorizationRequest.class), |
||||
TypeReference.of(AuthorizationGrantType.class), |
||||
TypeReference.of(OAuth2AuthorizationResponseType.class), |
||||
TypeReference.of(OAuth2TokenFormat.class) |
||||
), builder -> |
||||
builder.withMembers(MemberCategory.DECLARED_FIELDS, |
||||
MemberCategory.INVOKE_DECLARED_CONSTRUCTORS, MemberCategory.INVOKE_DECLARED_METHODS) |
||||
); |
||||
|
||||
// Jackson Modules - Spring Security and Spring Authorization Server
|
||||
hints.reflection().registerTypes( |
||||
Arrays.asList( |
||||
TypeReference.of(CoreJackson2Module.class), |
||||
TypeReference.of(WebServletJackson2Module.class), |
||||
TypeReference.of(OAuth2ClientJackson2Module.class), |
||||
TypeReference.of(OAuth2AuthorizationServerJackson2Module.class) |
||||
), builder -> |
||||
builder.withMembers(MemberCategory.DECLARED_FIELDS, |
||||
MemberCategory.INVOKE_DECLARED_CONSTRUCTORS, MemberCategory.INVOKE_DECLARED_METHODS) |
||||
); |
||||
|
||||
// Jackson Mixins - Spring Security and Spring Authorization Server
|
||||
try { |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.jackson2.UnmodifiableSetMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.jackson2.UnmodifiableListMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.jackson2.UnmodifiableMapMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.server.authorization.jackson2.UnmodifiableMapMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.server.authorization.jackson2.HashSetMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.web.jackson2.WebAuthenticationDetailsMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.jackson2.UsernamePasswordAuthenticationTokenMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.jackson2.UserMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.OAuth2AuthenticationTokenMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.DefaultOidcUserMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.DefaultOAuth2UserMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.OidcUserAuthorityMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.OAuth2UserAuthorityMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.jackson2.SimpleGrantedAuthorityMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.OidcIdTokenMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.client.jackson2.OidcUserInfoMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.server.authorization.jackson2.OAuth2AuthorizationRequestMixin")); |
||||
this.reflectionHintsRegistrar.registerReflectionHints(hints.reflection(), |
||||
Class.forName("org.springframework.security.oauth2.server.authorization.jackson2.OAuth2TokenFormatMixin")); |
||||
} catch (ClassNotFoundException ex) { |
||||
throw new RuntimeException(ex); |
||||
} |
||||
|
||||
// Sql Schema Resources
|
||||
hints.resources().registerPattern( |
||||
"org/springframework/security/oauth2/server/authorization/client/oauth2-registered-client-schema.sql"); |
||||
hints.resources().registerPattern( |
||||
"org/springframework/security/oauth2/server/authorization/oauth2-authorization-schema.sql"); |
||||
hints.resources().registerPattern( |
||||
"org/springframework/security/oauth2/server/authorization/oauth2-authorization-consent-schema.sql"); |
||||
} |
||||
|
||||
} |
||||
Loading…
Reference in new issue