|
Apache Tomcat 7.0.28 | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.catalina.util.LifecycleBase org.apache.catalina.util.LifecycleMBeanBase org.apache.catalina.realm.RealmBase org.apache.catalina.realm.DataSourceRealm
public class DataSourceRealm
Implementation of Realm that works with any JDBC JNDI DataSource. See the JDBCRealm.howto for more details on how to set up the database and for configuration options.
Nested Class Summary |
---|
Nested classes/interfaces inherited from class org.apache.catalina.realm.RealmBase |
---|
RealmBase.AllRolesMode |
Field Summary | |
---|---|
protected String |
dataSourceName
The name of the JNDI JDBC DataSource |
protected static String |
info
Descriptive information about this Realm implementation. |
protected boolean |
localDataSource
Context local datasource. |
protected static String |
name
Descriptive information about this Realm implementation. |
protected String |
roleNameCol
The column in the user role table that names a role |
protected String |
userCredCol
The column in the user table that holds the user's credentials |
protected String |
userNameCol
The column in the user table that holds the user's name |
protected String |
userRoleTable
The table that holds the relation between user's and roles |
protected String |
userTable
The table that holds user data. |
Fields inherited from class org.apache.catalina.realm.RealmBase |
---|
allRolesMode, container, containerLog, digest, digestEncoding, md, md5Encoder, md5Helper, realmPath, sm, stripRealmForGss, support, validate, x509UsernameRetriever, x509UsernameRetrieverClassName |
Fields inherited from class org.apache.catalina.util.LifecycleMBeanBase |
---|
mserver |
Fields inherited from interface org.apache.catalina.Lifecycle |
---|
AFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT |
Constructor Summary | |
---|---|
DataSourceRealm()
|
Method Summary | |
---|---|
protected Principal |
authenticate(Connection dbConnection,
String username,
String credentials)
Return the Principal associated with the specified username and credentials, if there is one; otherwise return null . |
Principal |
authenticate(String username,
String credentials)
Return the Principal associated with the specified username and credentials, if there is one; otherwise return null . |
protected void |
close(Connection dbConnection)
Close the specified database connection. |
String |
getDataSourceName()
Return the name of the JNDI JDBC DataSource. |
String |
getInfo()
Return descriptive information about this Realm implementation and the corresponding version number, in the format <description>/<version> . |
boolean |
getLocalDataSource()
Return if the datasource will be looked up in the webapp JNDI Context. |
protected String |
getName()
Return a short name for this Realm implementation. |
protected String |
getPassword(Connection dbConnection,
String username)
Return the password associated with the given principal's user name. |
protected String |
getPassword(String username)
Return the password associated with the given principal's user name. |
protected Principal |
getPrincipal(String username)
Return the Principal associated with the given user name. |
String |
getRoleNameCol()
Return the column in the user role table that names a role. |
protected ArrayList<String> |
getRoles(Connection dbConnection,
String username)
Return the roles associated with the given user name |
protected ArrayList<String> |
getRoles(String username)
Return the roles associated with the given user name. |
String |
getUserCredCol()
Return the column in the user table that holds the user's credentials. |
String |
getUserNameCol()
Return the column in the user table that holds the user's name. |
String |
getUserRoleTable()
Return the table that holds the relation between user's and roles. |
String |
getUserTable()
Return the table that holds user data.. |
protected Connection |
open()
Open the specified database connection. |
void |
setDataSourceName(String dataSourceName)
Set the name of the JNDI JDBC DataSource. |
void |
setLocalDataSource(boolean localDataSource)
Set to true to cause the datasource to be looked up in the webapp JNDI Context. |
void |
setRoleNameCol(String roleNameCol)
Set the column in the user role table that names a role. |
void |
setUserCredCol(String userCredCol)
Set the column in the user table that holds the user's credentials. |
void |
setUserNameCol(String userNameCol)
Set the column in the user table that holds the user's name. |
void |
setUserRoleTable(String userRoleTable)
Set the table that holds the relation between user's and roles. |
void |
setUserTable(String userTable)
Set the table that holds user data. |
protected void |
startInternal()
Prepare for the beginning of active use of the public methods of this component and implement the requirements of LifecycleBase.startInternal() . |
Methods inherited from class org.apache.catalina.util.LifecycleMBeanBase |
---|
destroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister |
Methods inherited from class org.apache.catalina.util.LifecycleBase |
---|
addLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, init, removeLifecycleListener, setState, setState, start, stop |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
protected String dataSourceName
protected static final String info
protected boolean localDataSource
protected static final String name
protected String roleNameCol
protected String userCredCol
protected String userNameCol
protected String userRoleTable
protected String userTable
Constructor Detail |
---|
public DataSourceRealm()
Method Detail |
---|
public String getDataSourceName()
public void setDataSourceName(String dataSourceName)
dataSourceName
- the name of the JNDI JDBC DataSourcepublic boolean getLocalDataSource()
public void setLocalDataSource(boolean localDataSource)
localDataSource
- the new flag valuepublic String getRoleNameCol()
public void setRoleNameCol(String roleNameCol)
roleNameCol
- The column namepublic String getUserCredCol()
public void setUserCredCol(String userCredCol)
userCredCol
- The column namepublic String getUserNameCol()
public void setUserNameCol(String userNameCol)
userNameCol
- The column namepublic String getUserRoleTable()
public void setUserRoleTable(String userRoleTable)
userRoleTable
- The table namepublic String getUserTable()
public void setUserTable(String userTable)
userTable
- The table namepublic String getInfo()
<description>/<version>
.
getInfo
in interface Realm
getInfo
in class RealmBase
public Principal authenticate(String username, String credentials)
null
.
If there are any errors with the JDBC connection, executing
the query or anything we return null (don't authenticate). This
event is also logged, and the connection will be closed so that
a subsequent request will automatically re-open it.
authenticate
in interface Realm
authenticate
in class RealmBase
username
- Username of the Principal to look upcredentials
- Password or other credentials to use in
authenticating this usernameprotected Principal authenticate(Connection dbConnection, String username, String credentials)
null
.
dbConnection
- The database connection to be usedusername
- Username of the Principal to look upcredentials
- Password or other credentials to use in
authenticating this usernameprotected void close(Connection dbConnection)
dbConnection
- The connection to be closedprotected Connection open()
protected String getName()
getName
in class RealmBase
protected String getPassword(String username)
getPassword
in class RealmBase
protected String getPassword(Connection dbConnection, String username)
dbConnection
- The database connection to be usedusername
- Username for which password should be retrievedprotected Principal getPrincipal(String username)
getPrincipal
in class RealmBase
protected ArrayList<String> getRoles(String username)
username
- Username for which roles should be retrievedprotected ArrayList<String> getRoles(Connection dbConnection, String username)
dbConnection
- The database connection to be usedusername
- Username for which roles should be retrievedprotected void startInternal() throws LifecycleException
LifecycleBase.startInternal()
.
startInternal
in class RealmBase
LifecycleException
- if this component detects a fatal error
that prevents this component from being used
|
Apache Tomcat 7.0.28 | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |