EnableGlobalMethodSecurity Misconfiguration Check
This polishes the EnableGlobalMethodSecurity misconfiguration check to not error if the user has specified a custom method security metadata source. Issue: gh-5341
This commit is contained in:
parent
1e864ad764
commit
73c1abbba0
|
@ -359,11 +359,12 @@ public class GlobalMethodSecurityConfiguration
|
||||||
sources.add(customMethodSecurityMetadataSource);
|
sources.add(customMethodSecurityMetadataSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean hasCustom = customMethodSecurityMetadataSource != null;
|
||||||
boolean isPrePostEnabled = prePostEnabled();
|
boolean isPrePostEnabled = prePostEnabled();
|
||||||
boolean isSecureEnabled = securedEnabled();
|
boolean isSecuredEnabled = securedEnabled();
|
||||||
boolean isJsr250Enabled = jsr250Enabled();
|
boolean isJsr250Enabled = jsr250Enabled();
|
||||||
|
|
||||||
if (!isPrePostEnabled && !isSecureEnabled && !isJsr250Enabled) {
|
if (!isPrePostEnabled && !isSecuredEnabled && !isJsr250Enabled && !hasCustom) {
|
||||||
throw new IllegalStateException("In the composition of all global method configuration, " +
|
throw new IllegalStateException("In the composition of all global method configuration, " +
|
||||||
"no annotation support was actually activated");
|
"no annotation support was actually activated");
|
||||||
}
|
}
|
||||||
|
@ -371,7 +372,7 @@ public class GlobalMethodSecurityConfiguration
|
||||||
if (isPrePostEnabled) {
|
if (isPrePostEnabled) {
|
||||||
sources.add(new PrePostAnnotationSecurityMetadataSource(attributeFactory));
|
sources.add(new PrePostAnnotationSecurityMetadataSource(attributeFactory));
|
||||||
}
|
}
|
||||||
if (isSecureEnabled) {
|
if (isSecuredEnabled) {
|
||||||
sources.add(new SecuredAnnotationSecurityMetadataSource());
|
sources.add(new SecuredAnnotationSecurityMetadataSource());
|
||||||
}
|
}
|
||||||
if (isJsr250Enabled) {
|
if (isJsr250Enabled) {
|
||||||
|
|
|
@ -15,10 +15,16 @@
|
||||||
*/
|
*/
|
||||||
package org.springframework.security.config.annotation.method.configuration;
|
package org.springframework.security.config.annotation.method.configuration;
|
||||||
|
|
||||||
|
import java.lang.reflect.Proxy;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.rules.ExpectedException;
|
import org.junit.rules.ExpectedException;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
import org.springframework.beans.BeansException;
|
import org.springframework.beans.BeansException;
|
||||||
import org.springframework.beans.factory.UnsatisfiedDependencyException;
|
import org.springframework.beans.factory.UnsatisfiedDependencyException;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
@ -31,6 +37,7 @@ import org.springframework.security.access.PermissionEvaluator;
|
||||||
import org.springframework.security.access.hierarchicalroles.RoleHierarchy;
|
import org.springframework.security.access.hierarchicalroles.RoleHierarchy;
|
||||||
import org.springframework.security.access.hierarchicalroles.RoleHierarchyImpl;
|
import org.springframework.security.access.hierarchicalroles.RoleHierarchyImpl;
|
||||||
import org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor;
|
import org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor;
|
||||||
|
import org.springframework.security.access.method.MethodSecurityMetadataSource;
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
import org.springframework.security.authentication.AuthenticationManager;
|
import org.springframework.security.authentication.AuthenticationManager;
|
||||||
import org.springframework.security.authentication.AuthenticationTrustResolver;
|
import org.springframework.security.authentication.AuthenticationTrustResolver;
|
||||||
|
@ -49,11 +56,6 @@ import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
||||||
|
|
||||||
import javax.sql.DataSource;
|
|
||||||
import java.lang.reflect.Proxy;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.assertj.core.api.Assertions.assertThatThrownBy;
|
import static org.assertj.core.api.Assertions.assertThatThrownBy;
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
@ -91,7 +93,7 @@ public class GlobalMethodSecurityConfigurationTests {
|
||||||
MockEventListener<AbstractAuthenticationEvent> events;
|
MockEventListener<AbstractAuthenticationEvent> events;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void illegalStateGlobalMethodSecurity() {
|
public void configureWhenGlobalMethodSecurityIsMissingMetadataSourceThenException() {
|
||||||
this.thrown.expect(UnsatisfiedDependencyException.class);
|
this.thrown.expect(UnsatisfiedDependencyException.class);
|
||||||
this.spring.register(IllegalStateGlobalMethodSecurityConfig.class).autowire();
|
this.spring.register(IllegalStateGlobalMethodSecurityConfig.class).autowire();
|
||||||
}
|
}
|
||||||
|
@ -101,6 +103,20 @@ public class GlobalMethodSecurityConfigurationTests {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void configureWhenGlobalMethodSecurityHasCustomMetadataSourceThenNoEnablingAttributeIsNeeded() {
|
||||||
|
this.spring.register(CustomMetadataSourceConfig.class).autowire();
|
||||||
|
}
|
||||||
|
|
||||||
|
@EnableGlobalMethodSecurity
|
||||||
|
public static class CustomMetadataSourceConfig extends GlobalMethodSecurityConfiguration {
|
||||||
|
@Bean
|
||||||
|
@Override
|
||||||
|
protected MethodSecurityMetadataSource customMethodSecurityMetadataSource() {
|
||||||
|
return mock(MethodSecurityMetadataSource.class);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void methodSecurityAuthenticationManagerPublishesEvent() {
|
public void methodSecurityAuthenticationManagerPublishesEvent() {
|
||||||
this.spring.register(InMemoryAuthWithGlobalMethodSecurityConfig.class).autowire();
|
this.spring.register(InMemoryAuthWithGlobalMethodSecurityConfig.class).autowire();
|
||||||
|
|
|
@ -15,16 +15,25 @@
|
||||||
*/
|
*/
|
||||||
package org.springframework.security.config.annotation.method.configuration;
|
package org.springframework.security.config.annotation.method.configuration;
|
||||||
|
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
|
||||||
import org.aopalliance.intercept.MethodInterceptor;
|
import org.aopalliance.intercept.MethodInterceptor;
|
||||||
import org.aopalliance.intercept.MethodInvocation;
|
import org.aopalliance.intercept.MethodInvocation;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.config.BeanDefinition;
|
import org.springframework.beans.factory.config.BeanDefinition;
|
||||||
import org.springframework.beans.factory.support.BeanDefinitionBuilder;
|
import org.springframework.beans.factory.support.BeanDefinitionBuilder;
|
||||||
import org.springframework.beans.factory.support.BeanDefinitionRegistry;
|
import org.springframework.beans.factory.support.BeanDefinitionRegistry;
|
||||||
import org.springframework.context.annotation.*;
|
import org.springframework.context.annotation.AdviceMode;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.context.annotation.Import;
|
||||||
|
import org.springframework.context.annotation.ImportBeanDefinitionRegistrar;
|
||||||
import org.springframework.core.Ordered;
|
import org.springframework.core.Ordered;
|
||||||
import org.springframework.core.type.AnnotationMetadata;
|
import org.springframework.core.type.AnnotationMetadata;
|
||||||
import org.springframework.security.access.AccessDecisionManager;
|
import org.springframework.security.access.AccessDecisionManager;
|
||||||
|
@ -46,12 +55,9 @@ import org.springframework.security.test.context.annotation.SecurityTestExecutio
|
||||||
import org.springframework.security.test.context.support.WithMockUser;
|
import org.springframework.security.test.context.support.WithMockUser;
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
|
||||||
import java.lang.reflect.Method;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import java.util.Arrays;
|
import static org.assertj.core.api.Assertions.assertThatCode;
|
||||||
import java.util.Collection;
|
import static org.assertj.core.api.Assertions.assertThatThrownBy;
|
||||||
import java.util.Collections;
|
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.*;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -263,7 +269,7 @@ public class NamespaceGlobalMethodSecurityTests {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EnableGlobalMethodSecurity(mode = AdviceMode.ASPECTJ)
|
@EnableGlobalMethodSecurity(mode = AdviceMode.ASPECTJ, securedEnabled = true)
|
||||||
public static class AspectJModeExtendsGMSCConfig extends GlobalMethodSecurityConfiguration {
|
public static class AspectJModeExtendsGMSCConfig extends GlobalMethodSecurityConfiguration {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue