Add constructors to facilitate constructor-based injection for required/shared bean properties.
This commit is contained in:
parent
73442125de
commit
2d271666a4
|
@ -50,6 +50,13 @@ public abstract class AbstractAccessDecisionManager implements AccessDecisionMan
|
||||||
|
|
||||||
private boolean allowIfAllAbstainDecisions = false;
|
private boolean allowIfAllAbstainDecisions = false;
|
||||||
|
|
||||||
|
protected AbstractAccessDecisionManager() {
|
||||||
|
}
|
||||||
|
|
||||||
|
protected AbstractAccessDecisionManager(List<AccessDecisionVoter> decisionVoters) {
|
||||||
|
this.decisionVoters = decisionVoters;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
public void afterPropertiesSet() throws Exception {
|
||||||
|
@ -76,6 +83,10 @@ public abstract class AbstractAccessDecisionManager implements AccessDecisionMan
|
||||||
this.allowIfAllAbstainDecisions = allowIfAllAbstainDecisions;
|
this.allowIfAllAbstainDecisions = allowIfAllAbstainDecisions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setDecisionVoters(List<AccessDecisionVoter> newList) {
|
public void setDecisionVoters(List<AccessDecisionVoter> newList) {
|
||||||
Assert.notEmpty(newList);
|
Assert.notEmpty(newList);
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
package org.springframework.security.access.vote;
|
package org.springframework.security.access.vote;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.*;
|
||||||
|
|
||||||
import org.springframework.security.access.AccessDecisionVoter;
|
import org.springframework.security.access.AccessDecisionVoter;
|
||||||
import org.springframework.security.access.AccessDeniedException;
|
import org.springframework.security.access.AccessDeniedException;
|
||||||
|
@ -28,6 +28,18 @@ import org.springframework.security.core.Authentication;
|
||||||
* <code>AccessDecisionVoter</code> returns an affirmative response.
|
* <code>AccessDecisionVoter</code> returns an affirmative response.
|
||||||
*/
|
*/
|
||||||
public class AffirmativeBased extends AbstractAccessDecisionManager {
|
public class AffirmativeBased extends AbstractAccessDecisionManager {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor which takes voter list
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public AffirmativeBased() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public AffirmativeBased(List<AccessDecisionVoter> decisionVoters) {
|
||||||
|
super(decisionVoters);
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
package org.springframework.security.access.vote;
|
package org.springframework.security.access.vote;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.*;
|
||||||
|
|
||||||
import org.springframework.security.access.AccessDecisionVoter;
|
import org.springframework.security.access.AccessDecisionVoter;
|
||||||
import org.springframework.security.access.AccessDeniedException;
|
import org.springframework.security.access.AccessDeniedException;
|
||||||
|
@ -34,6 +34,17 @@ public class ConsensusBased extends AbstractAccessDecisionManager {
|
||||||
|
|
||||||
private boolean allowIfEqualGrantedDeniedDecisions = true;
|
private boolean allowIfEqualGrantedDeniedDecisions = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor which takes voter list
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public ConsensusBased() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public ConsensusBased(List<AccessDecisionVoter> decisionVoters) {
|
||||||
|
super(decisionVoters);
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -30,6 +30,18 @@ import org.springframework.security.core.Authentication;
|
||||||
* voters to abstain or grant access.
|
* voters to abstain or grant access.
|
||||||
*/
|
*/
|
||||||
public class UnanimousBased extends AbstractAccessDecisionManager {
|
public class UnanimousBased extends AbstractAccessDecisionManager {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor which takes voter list
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public UnanimousBased() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public UnanimousBased(List<AccessDecisionVoter> decisionVoters) {
|
||||||
|
super(decisionVoters);
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -40,11 +40,22 @@ public class AnonymousAuthenticationProvider implements AuthenticationProvider,
|
||||||
protected MessageSourceAccessor messages = SpringSecurityMessageSource.getAccessor();
|
protected MessageSourceAccessor messages = SpringSecurityMessageSource.getAccessor();
|
||||||
private String key;
|
private String key;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public AnonymousAuthenticationProvider() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public AnonymousAuthenticationProvider(String key) {
|
||||||
|
this.key = key;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
public void afterPropertiesSet() throws Exception {
|
||||||
Assert.hasLength(key, "A Key is required");
|
Assert.hasLength(key, "A Key is required");
|
||||||
Assert.notNull(this.messages, "A message source must be set");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Authentication authenticate(Authentication authentication)
|
public Authentication authenticate(Authentication authentication)
|
||||||
|
@ -65,11 +76,17 @@ public class AnonymousAuthenticationProvider implements AuthenticationProvider,
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setKey(String key) {
|
public void setKey(String key) {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setMessageSource(MessageSource messageSource) {
|
public void setMessageSource(MessageSource messageSource) {
|
||||||
|
Assert.notNull(messageSource, "messageSource cannot be null");
|
||||||
this.messages = new MessageSourceAccessor(messageSource);
|
this.messages = new MessageSourceAccessor(messageSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -88,6 +88,22 @@ public class ProviderManager implements AuthenticationManager, MessageSourceAwar
|
||||||
private boolean eraseCredentialsAfterAuthentication = true;
|
private boolean eraseCredentialsAfterAuthentication = true;
|
||||||
private boolean clearExtraInformation = false;
|
private boolean clearExtraInformation = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor which takes provider list
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public ProviderManager() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProviderManager(List<AuthenticationProvider> providers) {
|
||||||
|
this(providers, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProviderManager(List<AuthenticationProvider> providers, AuthenticationManager parent) {
|
||||||
|
this.providers = providers;
|
||||||
|
this.parent = parent;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
public void afterPropertiesSet() throws Exception {
|
||||||
|
@ -212,6 +228,10 @@ public class ProviderManager implements AuthenticationManager, MessageSourceAwar
|
||||||
this.messages = new MessageSourceAccessor(messageSource);
|
this.messages = new MessageSourceAccessor(messageSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setParent(AuthenticationManager parent) {
|
public void setParent(AuthenticationManager parent) {
|
||||||
this.parent = parent;
|
this.parent = parent;
|
||||||
}
|
}
|
||||||
|
@ -244,7 +264,9 @@ public class ProviderManager implements AuthenticationManager, MessageSourceAwar
|
||||||
*
|
*
|
||||||
* @throws IllegalArgumentException if the list is empty or null, or any of the elements in the list is not an
|
* @throws IllegalArgumentException if the list is empty or null, or any of the elements in the list is not an
|
||||||
* AuthenticationProvider instance.
|
* AuthenticationProvider instance.
|
||||||
|
* @deprecated Use constructor injection
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public void setProviders(List providers) {
|
public void setProviders(List providers) {
|
||||||
Assert.notNull(providers, "Providers list cannot be null");
|
Assert.notNull(providers, "Providers list cannot be null");
|
||||||
|
|
|
@ -37,6 +37,17 @@ public class RememberMeAuthenticationProvider implements AuthenticationProvider,
|
||||||
protected MessageSourceAccessor messages = SpringSecurityMessageSource.getAccessor();
|
protected MessageSourceAccessor messages = SpringSecurityMessageSource.getAccessor();
|
||||||
private String key;
|
private String key;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public RememberMeAuthenticationProvider() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public RememberMeAuthenticationProvider(String key) {
|
||||||
|
this.key = key;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
public void afterPropertiesSet() throws Exception {
|
||||||
|
@ -61,6 +72,11 @@ public class RememberMeAuthenticationProvider implements AuthenticationProvider,
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setKey(String key) {
|
public void setKey(String key) {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
}
|
}
|
||||||
|
|
|
@ -206,23 +206,19 @@ public class ProviderManagerTests {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void parentAuthenticationIsUsedIfProvidersDontAuthenticate() throws Exception {
|
public void parentAuthenticationIsUsedIfProvidersDontAuthenticate() throws Exception {
|
||||||
ProviderManager mgr = new ProviderManager();
|
|
||||||
mgr.setProviders(Arrays.asList(mock(AuthenticationProvider.class)));
|
|
||||||
Authentication authReq = mock(Authentication.class);
|
|
||||||
AuthenticationManager parent = mock(AuthenticationManager.class);
|
AuthenticationManager parent = mock(AuthenticationManager.class);
|
||||||
|
Authentication authReq = mock(Authentication.class);
|
||||||
when(parent.authenticate(authReq)).thenReturn(authReq);
|
when(parent.authenticate(authReq)).thenReturn(authReq);
|
||||||
mgr.setParent(parent);
|
ProviderManager mgr = new ProviderManager(Arrays.asList(mock(AuthenticationProvider.class)), parent);
|
||||||
assertSame(authReq, mgr.authenticate(authReq));
|
assertSame(authReq, mgr.authenticate(authReq));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void parentIsNotCalledIfAccountStatusExceptionIsThrown() throws Exception {
|
public void parentIsNotCalledIfAccountStatusExceptionIsThrown() throws Exception {
|
||||||
ProviderManager mgr = new ProviderManager();
|
|
||||||
AuthenticationProvider iThrowAccountStatusException =
|
AuthenticationProvider iThrowAccountStatusException =
|
||||||
createProviderWhichThrows(new AccountStatusException("", new Throwable()){});
|
createProviderWhichThrows(new AccountStatusException("", new Throwable()){});
|
||||||
mgr.setProviders(Arrays.asList(iThrowAccountStatusException));
|
|
||||||
AuthenticationManager parent = mock(AuthenticationManager.class);
|
AuthenticationManager parent = mock(AuthenticationManager.class);
|
||||||
mgr.setParent(parent);
|
ProviderManager mgr = new ProviderManager(Arrays.asList(iThrowAccountStatusException), parent);
|
||||||
try {
|
try {
|
||||||
mgr.authenticate(mock(Authentication.class));
|
mgr.authenticate(mock(Authentication.class));
|
||||||
fail("Expected exception");
|
fail("Expected exception");
|
||||||
|
@ -252,16 +248,15 @@ public class ProviderManagerTests {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void authenticationExceptionFromParentOverridesPreviousOnes() throws Exception {
|
public void authenticationExceptionFromParentOverridesPreviousOnes() throws Exception {
|
||||||
ProviderManager mgr = new ProviderManager();
|
AuthenticationManager parent = mock(AuthenticationManager.class);
|
||||||
|
ProviderManager mgr = new ProviderManager(
|
||||||
|
Arrays.asList(createProviderWhichThrows(new BadCredentialsException(""))), parent);
|
||||||
final Authentication authReq = mock(Authentication.class);
|
final Authentication authReq = mock(Authentication.class);
|
||||||
AuthenticationEventPublisher publisher = mock(AuthenticationEventPublisher.class);
|
AuthenticationEventPublisher publisher = mock(AuthenticationEventPublisher.class);
|
||||||
mgr.setAuthenticationEventPublisher(publisher);
|
mgr.setAuthenticationEventPublisher(publisher);
|
||||||
// Set a provider that throws an exception - this is the exception we expect to be propagated
|
// Set a provider that throws an exception - this is the exception we expect to be propagated
|
||||||
final BadCredentialsException expected = new BadCredentialsException("I'm the one from the parent");
|
final BadCredentialsException expected = new BadCredentialsException("I'm the one from the parent");
|
||||||
mgr.setProviders(Arrays.asList(createProviderWhichThrows(new BadCredentialsException(""))));
|
|
||||||
AuthenticationManager parent = mock(AuthenticationManager.class);
|
|
||||||
when(parent.authenticate(authReq)).thenThrow(expected);
|
when(parent.authenticate(authReq)).thenThrow(expected);
|
||||||
mgr.setParent(parent);
|
|
||||||
try {
|
try {
|
||||||
mgr.authenticate(authReq);
|
mgr.authenticate(authReq);
|
||||||
fail("Expected exception");
|
fail("Expected exception");
|
||||||
|
@ -297,10 +292,7 @@ public class ProviderManagerTests {
|
||||||
List<AuthenticationProvider> providers = new ArrayList<AuthenticationProvider>();
|
List<AuthenticationProvider> providers = new ArrayList<AuthenticationProvider>();
|
||||||
providers.add(provider1);
|
providers.add(provider1);
|
||||||
|
|
||||||
ProviderManager mgr = new ProviderManager();
|
return new ProviderManager(providers);
|
||||||
mgr.setProviders(providers);
|
|
||||||
|
|
||||||
return mgr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//~ Inner Classes ==================================================================================================
|
//~ Inner Classes ==================================================================================================
|
||||||
|
|
|
@ -79,6 +79,22 @@ public class ExceptionTranslationFilter extends GenericFilterBean {
|
||||||
|
|
||||||
private RequestCache requestCache = new HttpSessionRequestCache();
|
private RequestCache requestCache = new HttpSessionRequestCache();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public ExceptionTranslationFilter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public ExceptionTranslationFilter(AuthenticationEntryPoint authenticationEntryPoint) {
|
||||||
|
this(authenticationEntryPoint, new HttpSessionRequestCache());
|
||||||
|
}
|
||||||
|
|
||||||
|
public ExceptionTranslationFilter(AuthenticationEntryPoint authenticationEntryPoint, RequestCache requestCache) {
|
||||||
|
this.authenticationEntryPoint = authenticationEntryPoint;
|
||||||
|
this.requestCache = requestCache;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -173,6 +189,10 @@ public class ExceptionTranslationFilter extends GenericFilterBean {
|
||||||
this.accessDeniedHandler = accessDeniedHandler;
|
this.accessDeniedHandler = accessDeniedHandler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setAuthenticationEntryPoint(AuthenticationEntryPoint authenticationEntryPoint) {
|
public void setAuthenticationEntryPoint(AuthenticationEntryPoint authenticationEntryPoint) {
|
||||||
this.authenticationEntryPoint = authenticationEntryPoint;
|
this.authenticationEntryPoint = authenticationEntryPoint;
|
||||||
}
|
}
|
||||||
|
@ -190,7 +210,10 @@ public class ExceptionTranslationFilter extends GenericFilterBean {
|
||||||
/**
|
/**
|
||||||
* The RequestCache implementation used to store the current request before starting authentication.
|
* The RequestCache implementation used to store the current request before starting authentication.
|
||||||
* Defaults to an {@link HttpSessionRequestCache}.
|
* Defaults to an {@link HttpSessionRequestCache}.
|
||||||
|
*
|
||||||
|
* @deprecated Use constructor
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setRequestCache(RequestCache requestCache) {
|
public void setRequestCache(RequestCache requestCache) {
|
||||||
Assert.notNull(requestCache, "requestCache cannot be null");
|
Assert.notNull(requestCache, "requestCache cannot be null");
|
||||||
this.requestCache = requestCache;
|
this.requestCache = requestCache;
|
||||||
|
|
|
@ -113,12 +113,7 @@ public abstract class AbstractAuthenticationProcessingFilter extends GenericFilt
|
||||||
protected AuthenticationDetailsSource<HttpServletRequest,?> authenticationDetailsSource = new WebAuthenticationDetailsSource();
|
protected AuthenticationDetailsSource<HttpServletRequest,?> authenticationDetailsSource = new WebAuthenticationDetailsSource();
|
||||||
private AuthenticationManager authenticationManager;
|
private AuthenticationManager authenticationManager;
|
||||||
protected MessageSourceAccessor messages = SpringSecurityMessageSource.getAccessor();
|
protected MessageSourceAccessor messages = SpringSecurityMessageSource.getAccessor();
|
||||||
|
private RememberMeServices rememberMeServices = new NullRememberMeServices();
|
||||||
/*
|
|
||||||
* Delay use of NullRememberMeServices until initialization so that namespace has a chance to inject
|
|
||||||
* the RememberMeServices implementation into custom implementations.
|
|
||||||
*/
|
|
||||||
private RememberMeServices rememberMeServices = null;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The URL destination that this filter intercepts and processes (usually
|
* The URL destination that this filter intercepts and processes (usually
|
||||||
|
@ -373,6 +368,7 @@ public abstract class AbstractAuthenticationProcessingFilter extends GenericFilt
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setRememberMeServices(RememberMeServices rememberMeServices) {
|
public void setRememberMeServices(RememberMeServices rememberMeServices) {
|
||||||
|
Assert.notNull("rememberMeServices cannot be null");
|
||||||
this.rememberMeServices = rememberMeServices;
|
this.rememberMeServices = rememberMeServices;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -81,6 +81,22 @@ public class LoginUrlAuthenticationEntryPoint implements AuthenticationEntryPoin
|
||||||
|
|
||||||
private final RedirectStrategy redirectStrategy = new DefaultRedirectStrategy();
|
private final RedirectStrategy redirectStrategy = new DefaultRedirectStrategy();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public LoginUrlAuthenticationEntryPoint() {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param loginFormUrl URL where the login page can be found. Should either be relative to the web-app context path
|
||||||
|
* (include a leading {@code /}) or an absolute URL.
|
||||||
|
*/
|
||||||
|
public LoginUrlAuthenticationEntryPoint(String loginFormUrl) {
|
||||||
|
this.loginFormUrl = loginFormUrl;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
public void afterPropertiesSet() throws Exception {
|
||||||
|
@ -228,7 +244,10 @@ public class LoginUrlAuthenticationEntryPoint implements AuthenticationEntryPoin
|
||||||
* The URL where the <code>UsernamePasswordAuthenticationFilter</code> login
|
* The URL where the <code>UsernamePasswordAuthenticationFilter</code> login
|
||||||
* page can be found. Should either be relative to the web-app context path
|
* page can be found. Should either be relative to the web-app context path
|
||||||
* (include a leading {@code /}) or an absolute URL.
|
* (include a leading {@code /}) or an absolute URL.
|
||||||
|
*
|
||||||
|
* @deprecated use constructor injection
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setLoginFormUrl(String loginFormUrl) {
|
public void setLoginFormUrl(String loginFormUrl) {
|
||||||
this.loginFormUrl = loginFormUrl;
|
this.loginFormUrl = loginFormUrl;
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,6 +59,18 @@ public abstract class AbstractRememberMeServices implements RememberMeServices,
|
||||||
private Boolean useSecureCookie = null;
|
private Boolean useSecureCookie = null;
|
||||||
private GrantedAuthoritiesMapper authoritiesMapper = new NullAuthoritiesMapper();
|
private GrantedAuthoritiesMapper authoritiesMapper = new NullAuthoritiesMapper();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use cosntructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
protected AbstractRememberMeServices() {
|
||||||
|
}
|
||||||
|
|
||||||
|
protected AbstractRememberMeServices(String key, UserDetailsService userDetailsService) {
|
||||||
|
this.key = key;
|
||||||
|
this.userDetailsService = userDetailsService;
|
||||||
|
}
|
||||||
|
|
||||||
public void afterPropertiesSet() throws Exception {
|
public void afterPropertiesSet() throws Exception {
|
||||||
Assert.hasLength(key);
|
Assert.hasLength(key);
|
||||||
Assert.notNull(userDetailsService, "A UserDetailsService is required");
|
Assert.notNull(userDetailsService, "A UserDetailsService is required");
|
||||||
|
@ -381,11 +393,21 @@ public abstract class AbstractRememberMeServices implements RememberMeServices,
|
||||||
return userDetailsService;
|
return userDetailsService;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setUserDetailsService(UserDetailsService userDetailsService) {
|
public void setUserDetailsService(UserDetailsService userDetailsService) {
|
||||||
Assert.notNull(userDetailsService, "UserDetailsService canot be null");
|
Assert.notNull(userDetailsService, "UserDetailsService canot be null");
|
||||||
this.userDetailsService = userDetailsService;
|
this.userDetailsService = userDetailsService;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setKey(String key) {
|
public void setKey(String key) {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@ import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import org.springframework.dao.DataAccessException;
|
import org.springframework.dao.DataAccessException;
|
||||||
import org.springframework.security.core.Authentication;
|
import org.springframework.security.core.Authentication;
|
||||||
|
import org.springframework.security.core.userdetails.UserDetailsService;
|
||||||
import org.springframework.security.crypto.codec.Base64;
|
import org.springframework.security.crypto.codec.Base64;
|
||||||
import org.springframework.security.core.userdetails.UserDetails;
|
import org.springframework.security.core.userdetails.UserDetails;
|
||||||
import org.springframework.security.web.authentication.RememberMeServices;
|
import org.springframework.security.web.authentication.RememberMeServices;
|
||||||
|
@ -48,8 +49,19 @@ public class PersistentTokenBasedRememberMeServices extends AbstractRememberMeSe
|
||||||
private int seriesLength = DEFAULT_SERIES_LENGTH;
|
private int seriesLength = DEFAULT_SERIES_LENGTH;
|
||||||
private int tokenLength = DEFAULT_TOKEN_LENGTH;
|
private int tokenLength = DEFAULT_TOKEN_LENGTH;
|
||||||
|
|
||||||
public PersistentTokenBasedRememberMeServices() throws Exception {
|
/**
|
||||||
random = SecureRandom.getInstance("SHA1PRNG");
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public PersistentTokenBasedRememberMeServices() {
|
||||||
|
random = new SecureRandom();
|
||||||
|
}
|
||||||
|
|
||||||
|
public PersistentTokenBasedRememberMeServices(String key, UserDetailsService userDetailsService,
|
||||||
|
PersistentTokenRepository tokenRepository) {
|
||||||
|
super(key, userDetailsService);
|
||||||
|
random = new SecureRandom();
|
||||||
|
this.tokenRepository = tokenRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -132,7 +144,6 @@ public class PersistentTokenBasedRememberMeServices extends AbstractRememberMeSe
|
||||||
addCookie(persistentToken, request, response);
|
addCookie(persistentToken, request, response);
|
||||||
} catch (DataAccessException e) {
|
} catch (DataAccessException e) {
|
||||||
logger.error("Failed to save persistent token ", e);
|
logger.error("Failed to save persistent token ", e);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,6 +172,10 @@ public class PersistentTokenBasedRememberMeServices extends AbstractRememberMeSe
|
||||||
setCookie(new String[] {token.getSeries(), token.getTokenValue()}, getTokenValiditySeconds(), request, response);
|
setCookie(new String[] {token.getSeries(), token.getTokenValue()}, getTokenValiditySeconds(), request, response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setTokenRepository(PersistentTokenRepository tokenRepository) {
|
public void setTokenRepository(PersistentTokenRepository tokenRepository) {
|
||||||
this.tokenRepository = tokenRepository;
|
this.tokenRepository = tokenRepository;
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,6 +67,19 @@ public class RememberMeAuthenticationFilter extends GenericFilterBean implements
|
||||||
private AuthenticationManager authenticationManager;
|
private AuthenticationManager authenticationManager;
|
||||||
private RememberMeServices rememberMeServices;
|
private RememberMeServices rememberMeServices;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public RememberMeAuthenticationFilter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public RememberMeAuthenticationFilter(AuthenticationManager authenticationManager,
|
||||||
|
RememberMeServices rememberMeServices) {
|
||||||
|
this.authenticationManager = authenticationManager;
|
||||||
|
this.rememberMeServices = rememberMeServices;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -159,10 +172,18 @@ public class RememberMeAuthenticationFilter extends GenericFilterBean implements
|
||||||
this.eventPublisher = eventPublisher;
|
this.eventPublisher = eventPublisher;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setAuthenticationManager(AuthenticationManager authenticationManager) {
|
public void setAuthenticationManager(AuthenticationManager authenticationManager) {
|
||||||
this.authenticationManager = authenticationManager;
|
this.authenticationManager = authenticationManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setRememberMeServices(RememberMeServices rememberMeServices) {
|
public void setRememberMeServices(RememberMeServices rememberMeServices) {
|
||||||
this.rememberMeServices = rememberMeServices;
|
this.rememberMeServices = rememberMeServices;
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
package org.springframework.security.web.authentication.rememberme;
|
package org.springframework.security.web.authentication.rememberme;
|
||||||
|
|
||||||
import org.springframework.security.core.Authentication;
|
import org.springframework.security.core.Authentication;
|
||||||
|
import org.springframework.security.core.userdetails.UserDetailsService;
|
||||||
import org.springframework.security.crypto.codec.Hex;
|
import org.springframework.security.crypto.codec.Hex;
|
||||||
import org.springframework.security.core.userdetails.UserDetails;
|
import org.springframework.security.core.userdetails.UserDetails;
|
||||||
import org.springframework.security.crypto.codec.Utf8;
|
import org.springframework.security.crypto.codec.Utf8;
|
||||||
|
@ -81,6 +82,17 @@ import java.util.Date;
|
||||||
*/
|
*/
|
||||||
public class TokenBasedRememberMeServices extends AbstractRememberMeServices {
|
public class TokenBasedRememberMeServices extends AbstractRememberMeServices {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use with-args constructor
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public TokenBasedRememberMeServices() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public TokenBasedRememberMeServices(String key, UserDetailsService userDetailsService) {
|
||||||
|
super(key, userDetailsService);
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -96,6 +96,37 @@ public class BasicAuthenticationFilter extends GenericFilterBean {
|
||||||
private boolean ignoreFailure = false;
|
private boolean ignoreFailure = false;
|
||||||
private String credentialsCharset = "UTF-8";
|
private String credentialsCharset = "UTF-8";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
public BasicAuthenticationFilter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance which will authenticate against the supplied {@code AuthenticationManager}
|
||||||
|
* and which will ignore failed authentication attempts, allowing the request to proceed down the filter chain.
|
||||||
|
*
|
||||||
|
* @param authenticationManager the bean to submit authentication requests to
|
||||||
|
*/
|
||||||
|
public BasicAuthenticationFilter(AuthenticationManager authenticationManager) {
|
||||||
|
this.authenticationManager = authenticationManager;
|
||||||
|
ignoreFailure = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance which will authenticate against the supplied {@code AuthenticationManager} and
|
||||||
|
* use the supplied {@code AuthenticationEntryPoint} to handle authentication failures.
|
||||||
|
*
|
||||||
|
* @param authenticationManager the bean to submit authentication requests to
|
||||||
|
* @param authenticationEntryPoint will be invoked when authentication fails. Typically an instance of
|
||||||
|
* {@link BasicAuthenticationEntryPoint}.
|
||||||
|
*/
|
||||||
|
public BasicAuthenticationFilter(AuthenticationManager authenticationManager,
|
||||||
|
AuthenticationEntryPoint authenticationEntryPoint) {
|
||||||
|
this.authenticationManager = authenticationManager;
|
||||||
|
this.authenticationEntryPoint = authenticationEntryPoint;
|
||||||
|
}
|
||||||
|
|
||||||
//~ Methods ========================================================================================================
|
//~ Methods ========================================================================================================
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -172,7 +203,7 @@ public class BasicAuthenticationFilter extends GenericFilterBean {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Decodes the header into a username and password.
|
* Decodes the header into a username and password.
|
||||||
* <p>
|
*
|
||||||
* @throws BadCredentialsException if the Basic header is not present or is not valid Base64
|
* @throws BadCredentialsException if the Basic header is not present or is not valid Base64
|
||||||
*/
|
*/
|
||||||
private String[] extractAndDecodeHeader(String header, HttpServletRequest request) throws IOException {
|
private String[] extractAndDecodeHeader(String header, HttpServletRequest request) throws IOException {
|
||||||
|
@ -237,6 +268,10 @@ public class BasicAuthenticationFilter extends GenericFilterBean {
|
||||||
return authenticationEntryPoint;
|
return authenticationEntryPoint;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setAuthenticationEntryPoint(AuthenticationEntryPoint authenticationEntryPoint) {
|
public void setAuthenticationEntryPoint(AuthenticationEntryPoint authenticationEntryPoint) {
|
||||||
this.authenticationEntryPoint = authenticationEntryPoint;
|
this.authenticationEntryPoint = authenticationEntryPoint;
|
||||||
}
|
}
|
||||||
|
@ -245,6 +280,10 @@ public class BasicAuthenticationFilter extends GenericFilterBean {
|
||||||
return authenticationManager;
|
return authenticationManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setAuthenticationManager(AuthenticationManager authenticationManager) {
|
public void setAuthenticationManager(AuthenticationManager authenticationManager) {
|
||||||
this.authenticationManager = authenticationManager;
|
this.authenticationManager = authenticationManager;
|
||||||
}
|
}
|
||||||
|
@ -253,6 +292,11 @@ public class BasicAuthenticationFilter extends GenericFilterBean {
|
||||||
return ignoreFailure;
|
return ignoreFailure;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @deprecated Use the constructor which takes a single AuthenticationManager parameter
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setIgnoreFailure(boolean ignoreFailure) {
|
public void setIgnoreFailure(boolean ignoreFailure) {
|
||||||
this.ignoreFailure = ignoreFailure;
|
this.ignoreFailure = ignoreFailure;
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,10 +43,17 @@ public class SecurityContextPersistenceFilter extends GenericFilterBean {
|
||||||
|
|
||||||
static final String FILTER_APPLIED = "__spring_security_scpf_applied";
|
static final String FILTER_APPLIED = "__spring_security_scpf_applied";
|
||||||
|
|
||||||
private SecurityContextRepository repo = new HttpSessionSecurityContextRepository();
|
private SecurityContextRepository repo;
|
||||||
|
|
||||||
private boolean forceEagerSessionCreation = false;
|
private boolean forceEagerSessionCreation = false;
|
||||||
|
|
||||||
|
public SecurityContextPersistenceFilter() {
|
||||||
|
this(new HttpSessionSecurityContextRepository());
|
||||||
|
}
|
||||||
|
|
||||||
|
public SecurityContextPersistenceFilter(SecurityContextRepository repo) {
|
||||||
|
this.repo = repo;
|
||||||
|
}
|
||||||
|
|
||||||
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
|
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
|
||||||
throws IOException, ServletException {
|
throws IOException, ServletException {
|
||||||
|
@ -92,6 +99,10 @@ public class SecurityContextPersistenceFilter extends GenericFilterBean {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setSecurityContextRepository(SecurityContextRepository repo) {
|
public void setSecurityContextRepository(SecurityContextRepository repo) {
|
||||||
Assert.notNull(repo, "SecurityContextRepository cannot be null");
|
Assert.notNull(repo, "SecurityContextRepository cannot be null");
|
||||||
this.repo = repo;
|
this.repo = repo;
|
||||||
|
|
|
@ -24,7 +24,15 @@ import org.springframework.web.filter.GenericFilterBean;
|
||||||
*/
|
*/
|
||||||
public class RequestCacheAwareFilter extends GenericFilterBean {
|
public class RequestCacheAwareFilter extends GenericFilterBean {
|
||||||
|
|
||||||
private RequestCache requestCache = new HttpSessionRequestCache();
|
private RequestCache requestCache;
|
||||||
|
|
||||||
|
public RequestCacheAwareFilter() {
|
||||||
|
this(new HttpSessionRequestCache());
|
||||||
|
}
|
||||||
|
|
||||||
|
public RequestCacheAwareFilter(RequestCache requestCache) {
|
||||||
|
this.requestCache = requestCache;
|
||||||
|
}
|
||||||
|
|
||||||
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
|
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
|
||||||
throws IOException, ServletException {
|
throws IOException, ServletException {
|
||||||
|
@ -35,6 +43,10 @@ public class RequestCacheAwareFilter extends GenericFilterBean {
|
||||||
chain.doFilter(wrappedSavedRequest == null ? request : wrappedSavedRequest, response);
|
chain.doFilter(wrappedSavedRequest == null ? request : wrappedSavedRequest, response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use constructor injection
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setRequestCache(RequestCache requestCache) {
|
public void setRequestCache(RequestCache requestCache) {
|
||||||
this.requestCache = requestCache;
|
this.requestCache = requestCache;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,14 +41,19 @@ public class SessionManagementFilter extends GenericFilterBean {
|
||||||
//~ Instance fields ================================================================================================
|
//~ Instance fields ================================================================================================
|
||||||
|
|
||||||
private final SecurityContextRepository securityContextRepository;
|
private final SecurityContextRepository securityContextRepository;
|
||||||
private SessionAuthenticationStrategy sessionStrategy = new SessionFixationProtectionStrategy();
|
private SessionAuthenticationStrategy sessionStrategy;
|
||||||
private final AuthenticationTrustResolver authenticationTrustResolver = new AuthenticationTrustResolverImpl();
|
private final AuthenticationTrustResolver authenticationTrustResolver = new AuthenticationTrustResolverImpl();
|
||||||
private String invalidSessionUrl;
|
private String invalidSessionUrl;
|
||||||
private AuthenticationFailureHandler failureHandler = new SimpleUrlAuthenticationFailureHandler();
|
private AuthenticationFailureHandler failureHandler = new SimpleUrlAuthenticationFailureHandler();
|
||||||
private RedirectStrategy redirectStrategy = new DefaultRedirectStrategy();
|
private RedirectStrategy redirectStrategy = new DefaultRedirectStrategy();
|
||||||
|
|
||||||
public SessionManagementFilter(SecurityContextRepository securityContextRepository) {
|
public SessionManagementFilter(SecurityContextRepository securityContextRepository) {
|
||||||
|
this(securityContextRepository, new SessionFixationProtectionStrategy());
|
||||||
|
}
|
||||||
|
|
||||||
|
public SessionManagementFilter(SecurityContextRepository securityContextRepository, SessionAuthenticationStrategy sessionStrategy) {
|
||||||
this.securityContextRepository = securityContextRepository;
|
this.securityContextRepository = securityContextRepository;
|
||||||
|
this.sessionStrategy = sessionStrategy;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
|
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
|
||||||
|
@ -105,7 +110,9 @@ public class SessionManagementFilter extends GenericFilterBean {
|
||||||
* user has been authenticated during the current request.
|
* user has been authenticated during the current request.
|
||||||
*
|
*
|
||||||
* @param sessionStrategy the strategy object. If not set, a {@link SessionFixationProtectionStrategy} is used.
|
* @param sessionStrategy the strategy object. If not set, a {@link SessionFixationProtectionStrategy} is used.
|
||||||
|
* @deprecated Use constructor injection
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public void setSessionAuthenticationStrategy(SessionAuthenticationStrategy sessionStrategy) {
|
public void setSessionAuthenticationStrategy(SessionAuthenticationStrategy sessionStrategy) {
|
||||||
Assert.notNull(sessionStrategy, "authenticatedSessionStratedy must not be null");
|
Assert.notNull(sessionStrategy, "authenticatedSessionStratedy must not be null");
|
||||||
this.sessionStrategy = sessionStrategy;
|
this.sessionStrategy = sessionStrategy;
|
||||||
|
|
|
@ -27,12 +27,13 @@ public class PersistentTokenBasedRememberMeServicesTests {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUpData() throws Exception {
|
public void setUpData() throws Exception {
|
||||||
services = new PersistentTokenBasedRememberMeServices();
|
services = new PersistentTokenBasedRememberMeServices("key",
|
||||||
|
new AbstractRememberMeServicesTests.MockUserDetailsService(AbstractRememberMeServicesTests.joe, false),
|
||||||
|
new InMemoryTokenRepositoryImpl());
|
||||||
services.setCookieName("mycookiename");
|
services.setCookieName("mycookiename");
|
||||||
// Default to 100 days (see SEC-1081).
|
// Default to 100 days (see SEC-1081).
|
||||||
services.setTokenValiditySeconds(100 * 24 * 60 * 60);
|
services.setTokenValiditySeconds(100 * 24 * 60 * 60);
|
||||||
services.setUserDetailsService(
|
services.afterPropertiesSet();
|
||||||
new AbstractRememberMeServicesTests.MockUserDetailsService(AbstractRememberMeServicesTests.joe, false));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = InvalidCookieException.class)
|
@Test(expected = InvalidCookieException.class)
|
||||||
|
@ -111,7 +112,7 @@ public class PersistentTokenBasedRememberMeServicesTests {
|
||||||
public void logoutClearsUsersTokenAndCookie() throws Exception {
|
public void logoutClearsUsersTokenAndCookie() throws Exception {
|
||||||
Cookie cookie = new Cookie("mycookiename", "somevalue");
|
Cookie cookie = new Cookie("mycookiename", "somevalue");
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest();
|
MockHttpServletRequest request = new MockHttpServletRequest();
|
||||||
request.setCookies(new Cookie[] {cookie});
|
request.setCookies(cookie);
|
||||||
MockHttpServletResponse response = new MockHttpServletResponse();
|
MockHttpServletResponse response = new MockHttpServletResponse();
|
||||||
MockTokenRepository repo =
|
MockTokenRepository repo =
|
||||||
new MockTokenRepository(new PersistentRememberMeToken("joe", "series","token", new Date()));
|
new MockTokenRepository(new PersistentRememberMeToken("joe", "series","token", new Date()));
|
||||||
|
|
Loading…
Reference in New Issue