public class RunAsImplAuthenticationProvider extends Object implements InitializingBean, AuthenticationProvider, MessageSourceAware
AuthenticationProvider implementation that can authenticate a RunAsUserToken.Configured in
the bean context with a key that should match the key used by adapters to generate the RunAsUserToken.
It treats as valid any RunAsUserToken instance presenting a hash code that matches the
RunAsImplAuthenticationProvider-configured key.
If the key does not match, a BadCredentialsException is thrown.
| Modifier and Type | Field and Description |
|---|---|
protected MessageSourceAccessor |
messages |
| Constructor and Description |
|---|
RunAsImplAuthenticationProvider() |
| Modifier and Type | Method and Description |
|---|---|
void |
afterPropertiesSet() |
Authentication |
authenticate(Authentication authentication)
Performs authentication with the same contract as
AuthenticationManager.authenticate(Authentication). |
String |
getKey() |
void |
setKey(String key) |
void |
setMessageSource(MessageSource messageSource) |
boolean |
supports(Class<?> authentication)
Returns
true if this AuthenticationProvider supports the indicated
Authentication object. |
protected MessageSourceAccessor messages
public void afterPropertiesSet()
throws Exception
afterPropertiesSet in interface InitializingBeanExceptionpublic Authentication authenticate(Authentication authentication) throws AuthenticationException
AuthenticationProviderAuthenticationManager.authenticate(Authentication).authenticate in interface AuthenticationProviderauthentication - the authentication request object.null if the
AuthenticationProvider is unable to support authentication of the passed
Authentication object. In such a case, the next AuthenticationProvider that
supports the presented Authentication class will be tried.AuthenticationException - if authentication fails.public String getKey()
public void setKey(String key)
public void setMessageSource(MessageSource messageSource)
setMessageSource in interface MessageSourceAwarepublic boolean supports(Class<?> authentication)
AuthenticationProvidertrue if this AuthenticationProvider supports the indicated
Authentication object.
Returning true does not guarantee an AuthenticationProvider will be able to
authenticate the presented instance of the Authentication class. It simply indicates it can support
closer evaluation of it. An AuthenticationProvider can still return null from the
AuthenticationProvider.authenticate(Authentication) method to indicate another AuthenticationProvider should be
tried.
Selection of an AuthenticationProvider capable of performing authentication is
conducted at runtime the ProviderManager.
supports in interface AuthenticationProvidertrue if the implementation can more closely evaluate the Authentication class
presented