public class CookieAuthenticationLoginModule extends AbstractLoginModule
jspwiki.workDir
, under the directory
"logincookies". For security purposes it is a very, very good idea
to prevent access to this directory by everyone except the web server process;
otherwise people having read access to this directory may be able to spoof
other users.
The cookie directory is scrubbed of old entries at regular intervals.
This module must be used with a CallbackHandler (such as
WebContainerCallbackHandler
) that supports the following Callback
types:
HttpRequestCallback
- supplies the cookie, which should contain
an unique id for fetching the UID.WikiEngineCallback
- allows access to the WikiEngine itself.
After authentication, a generic WikiPrincipal based on the username will be created and associated with the Subject.
LoginModule.commit()
,
CookieAssertionLoginModule
Modifier and Type | Field and Description |
---|---|
protected static String |
COOKIE_DIR
The directory name under which the cookies are stored.
|
static String |
PROP_LOGIN_EXPIRY_DAYS
User property for setting how long the cookie is stored on the user's computer.
|
m_handler, m_options, m_principals, m_state, m_subject, NULL
Constructor and Description |
---|
CookieAuthenticationLoginModule() |
Modifier and Type | Method and Description |
---|---|
static void |
clearLoginCookie(WikiEngine engine,
javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response)
Clears away the login cookie, and removes the uid-username mapping file as well.
|
boolean |
login()
Logs in the user by calling back to the registered CallbackHandler with a
series of callbacks.
|
static void |
setLoginCookie(WikiEngine engine,
javax.servlet.http.HttpServletResponse response,
String username)
Sets a login cookie based on properties set by the user.
|
abort, commit, initialize, logout
protected static final String COOKIE_DIR
public static final String PROP_LOGIN_EXPIRY_DAYS
public CookieAuthenticationLoginModule()
public boolean login() throws LoginException
AbstractLoginModule
true
login
in interface LoginModule
login
in class AbstractLoginModule
true
if the commit succeeded, or
false
if this LoginModule should be ignored.LoginException
- if the authentication fails{@inheritDoc}
public static void setLoginCookie(WikiEngine engine, javax.servlet.http.HttpServletResponse response, String username)
engine
- The WikiEngineresponse
- The HttpServletResponseusername
- The username for whom to create the cookie.public static void clearLoginCookie(WikiEngine engine, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response)
engine
- WikiEnginerequest
- Servlet requestresponse
- Servlet responseCopyright © 2001-2019 The Apache Software Foundation. All rights reserved.