|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.hadoop.security.authentication.server.AuthenticationFilter
@InterfaceAudience.Private @InterfaceStability.Unstable public class AuthenticationFilter
The AuthenticationFilter enables protecting web application resources with different (pluggable)
authentication mechanisms and signer secret providers.
AuthenticationHandler interface.
This filter delegates to the configured authentication handler for authentication and once it obtains an
AuthenticationToken from it, sets a signed HTTP cookie with the token. For client requests
that provide the signed HTTP cookie, it verifies the validity of the cookie, extracts the user information
and lets the request proceed to the target resource.
The supported configuration properties are:
PseudoAuthenticationHandler, 'kerberos' is short for KerberosAuthenticationHandler, otherwise
the full class name of the AuthenticationHandler must be specified.3600 seconds. This is also used for the rollover interval for
the "random" and "zookeeper" SignerSecretProviders.AuthenticationHandler implementation and the
AuthenticationFilter will take all the properties that start with the prefix #PREFIX#, it will remove
the prefix from it and it will pass them to the the authentication handler for initialization. Properties that do
not start with the prefix will not be passed to the authentication handler initialization.
Out of the box it provides 3 signer secret provider implementations:
"string", "random", and "zookeeper"
Additional signer secret providers are supported via the
SignerSecretProvider class.
For the HTTP cookies mentioned above, the SignerSecretProvider is used to
determine the secret to use for signing the cookies. Different
implementations can have different behaviors. The "string" implementation
simply uses the string set in the [#PREFIX#.]signature.secret property
mentioned above. The "random" implementation uses a randomly generated
secret that rolls over at the interval specified by the
[#PREFIX#.]token.validity mentioned above. The "zookeeper" implementation
is like the "random" one, except that it synchronizes the random secret
and rollovers between multiple servers; it's meant for HA services.
The relevant configuration properties are:
ZKSignerSecretProvider for details.
For subclasses of AuthenticationFilter that want additional control over the
SignerSecretProvider, they can use the following attribute set in the
ServletContext:
| Field Summary | |
|---|---|
static String |
AUTH_TOKEN_VALIDITY
Constant for the configuration property that indicates the validity of the generated token. |
static String |
AUTH_TYPE
Constant for the property that specifies the authentication handler to use. |
static String |
CONFIG_PREFIX
Constant for the property that specifies the configuration prefix. |
static String |
COOKIE_DOMAIN
Constant for the configuration property that indicates the domain to use in the HTTP cookie. |
static String |
COOKIE_PATH
Constant for the configuration property that indicates the path to use in the HTTP cookie. |
static String |
SIGNATURE_SECRET
Constant for the property that specifies the secret to use for signing the HTTP Cookies. |
static String |
SIGNER_SECRET_PROVIDER
Constant for the configuration property that indicates the name of the SignerSecretProvider class to use. |
static String |
SIGNER_SECRET_PROVIDER_ATTRIBUTE
Constant for the ServletContext attribute that can be used for providing a custom implementation of the SignerSecretProvider. |
| Constructor Summary | |
|---|---|
AuthenticationFilter()
|
|
| Method Summary | |
|---|---|
static void |
createAuthCookie(javax.servlet.http.HttpServletResponse resp,
String token,
String domain,
String path,
long expires,
boolean isSecure)
Creates the Hadoop authentication HTTP cookie. |
void |
destroy()
Destroys the filter. |
protected void |
doFilter(javax.servlet.FilterChain filterChain,
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
Delegates call to the servlet filter chain. |
void |
doFilter(javax.servlet.ServletRequest request,
javax.servlet.ServletResponse response,
javax.servlet.FilterChain filterChain)
If the request has a valid authentication token it allows the request to continue to the target resource, otherwise it triggers an authentication sequence using the configured AuthenticationHandler. |
protected AuthenticationHandler |
getAuthenticationHandler()
Returns the authentication handler being used. |
protected Properties |
getConfiguration()
Returns the configuration properties of the AuthenticationFilter
without the prefix. |
protected Properties |
getConfiguration(String configPrefix,
javax.servlet.FilterConfig filterConfig)
Returns the filtered configuration (only properties starting with the specified prefix). |
protected String |
getCookieDomain()
Returns the cookie domain to use for the HTTP cookie. |
protected String |
getCookiePath()
Returns the cookie path to use for the HTTP cookie. |
protected String |
getRequestURL(javax.servlet.http.HttpServletRequest request)
Returns the full URL of the request including the query string. |
protected AuthenticationToken |
getToken(javax.servlet.http.HttpServletRequest request)
Returns the AuthenticationToken for the request. |
protected long |
getValidity()
Returns the validity time of the generated tokens. |
void |
init(javax.servlet.FilterConfig filterConfig)
Initializes the authentication filter and signer secret provider. |
protected boolean |
isCustomSignerSecretProvider()
Returns if a custom implementation of a SignerSecretProvider is being used. |
protected boolean |
isRandomSecret()
Returns if a random secret is being used. |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Field Detail |
|---|
public static final String CONFIG_PREFIX
public static final String AUTH_TYPE
public static final String SIGNATURE_SECRET
public static final String AUTH_TOKEN_VALIDITY
public static final String COOKIE_DOMAIN
public static final String COOKIE_PATH
public static final String SIGNER_SECRET_PROVIDER
public static final String SIGNER_SECRET_PROVIDER_ATTRIBUTE
| Constructor Detail |
|---|
public AuthenticationFilter()
| Method Detail |
|---|
public void init(javax.servlet.FilterConfig filterConfig)
throws javax.servlet.ServletException
AuthenticationHandler.
init in interface javax.servlet.FilterfilterConfig - filter configuration.
javax.servlet.ServletException - thrown if the filter or the authentication handler could not be initialized properly.protected Properties getConfiguration()
AuthenticationFilter
without the prefix. The returned properties are the same that the
getConfiguration(String, FilterConfig) method returned.
protected AuthenticationHandler getAuthenticationHandler()
protected boolean isRandomSecret()
protected boolean isCustomSignerSecretProvider()
protected long getValidity()
protected String getCookieDomain()
protected String getCookiePath()
public void destroy()
AuthenticationHandler.destroy() method to release any resources it may hold.
destroy in interface javax.servlet.Filter
protected Properties getConfiguration(String configPrefix,
javax.servlet.FilterConfig filterConfig)
throws javax.servlet.ServletException
Properties object is used to initialized the
AuthenticationHandler.
This method can be overriden by subclasses to obtain the configuration from other configuration source than
the web.xml file.
configPrefix - configuration prefix to use for extracting configuration properties.filterConfig - filter configuration object
AuthenticationHandler instance.
javax.servlet.ServletException - thrown if the configuration could not be created.protected String getRequestURL(javax.servlet.http.HttpServletRequest request)
request - the request object.
protected AuthenticationToken getToken(javax.servlet.http.HttpServletRequest request)
throws IOException,
AuthenticationException
AuthenticationToken for the request.
It looks at the received HTTP cookies and extracts the value of the AuthenticatedURL.AUTH_COOKIE
if present. It verifies the signature and if correct it creates the AuthenticationToken and returns
it.
If this method returns null the filter will invoke the configured AuthenticationHandler
to perform user authentication.
request - request object.
null otherwise.
IOException - thrown if an IO error occurred.
AuthenticationException - thrown if the token is invalid or if it has expired.
public void doFilter(javax.servlet.ServletRequest request,
javax.servlet.ServletResponse response,
javax.servlet.FilterChain filterChain)
throws IOException,
javax.servlet.ServletException
AuthenticationHandler.
doFilter in interface javax.servlet.Filterrequest - the request object.response - the response object.filterChain - the filter chain object.
IOException - thrown if an IO error occurred.
javax.servlet.ServletException - thrown if a processing error occurred.
protected void doFilter(javax.servlet.FilterChain filterChain,
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
throws IOException,
javax.servlet.ServletException
IOException
javax.servlet.ServletException
public static void createAuthCookie(javax.servlet.http.HttpServletResponse resp,
String token,
String domain,
String path,
long expires,
boolean isSecure)
token - authentication token for the cookie.expires - UNIX timestamp that indicates the expire date of the
cookie. It has no effect if its value < 0.
XXX the following code duplicate some logic in Jetty / Servlet API,
because of the fact that Hadoop is stuck at servlet 2.5 and jetty 6
right now.
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||