| 
 | Apache Tomcat 6.0.53 | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectorg.apache.catalina.realm.RealmBase
org.apache.catalina.realm.JNDIRealm
public class JNDIRealm
Implementation of Realm that works with a directory server accessed via the Java Naming and Directory Interface (JNDI) APIs. The following constraints are imposed on the data structure in the underlying directory server:
DirContext that is accessed
     via the connectionURL property.connectURL
     an attempt will be made to use the alternateURL if it
     exists.userPattern property.userPattern property is not
     specified, a unique element can be located by searching the directory
     context. In this case:
     userSearch pattern specifies the search filter
         after substitution of the username.userBase property can be set to the element that
         is the base of the subtree containing users.  If not specified,
         the search base is the top-level context.userSubtree property can be set to
         true if you wish to search the entire subtree of the
         directory context.  The default value of false
         requests a search of only the current level.userPassword property is not specified.userPassword
     property is specified, in which case:
     userPassword property.
     RealmBase.digest() method (using the standard digest
         support included in RealmBase).
     RealmBase.digest()) are equal to the retrieved value
         for the user password attribute.DirContext that is accessed via the
     connectionURL property.  This element has the following
     characteristics:
     roleSearch
         property.roleSearch pattern optionally includes pattern
         replacements "{0}" for the distinguished name, and/or "{1}" for
         the username, of the authenticated user for which roles will be
         retrieved.roleBase property can be set to the element that
         is the base of the search for matching roles.  If not specified,
         the entire context will be searched.roleSubtree property can be set to
         true if you wish to search the entire subtree of the
         directory context.  The default value of false
         requests a search of only the current level.roleName property) containing the name of the
         role represented by this element.userRoleName property.commonRole property to the
 name of this role. The role doesn't have to exist in the directory.roleNested to true.
 The default value is false, so role searches will not find
 nested roles.<security-role-ref> element in
     the web application deployment descriptor allows applications to refer
     to roles programmatically by names other than those used in the
     directory server itself.TODO - Support connection pooling (including message
 format objects) so that authenticate() does not have to be
 synchronized.
WARNING - There is a reported bug against the Netscape provider code (com.netscape.jndi.ldap.LdapContextFactory) with respect to successfully authenticated a non-existing user. The report is here: http://bz.apache.org/bugzilla/show_bug.cgi?id=11210 . With luck, Netscape has updated their provider code and this is not an issue.
| Nested Class Summary | |
|---|---|
| protected static class | JNDIRealm.UserA protected class representing a User | 
| Nested classes/interfaces inherited from class org.apache.catalina.realm.RealmBase | 
|---|
| RealmBase.AllRolesMode | 
| Field Summary | |
|---|---|
| protected  boolean | adCompatShould we ignore PartialResultExceptions when iterating over NamingEnumerations? | 
| protected  java.lang.String | alternateURLAn alternate URL, to which, we should connect if connectionURL fails. | 
| protected  java.lang.String | authenticationThe type of authentication to use | 
| protected  java.lang.String | commonRoleAdd this role to every authenticated user | 
| protected  int | connectionAttemptThe number of connection attempts. | 
| protected  java.lang.String | connectionNameThe connection username for the server we will contact. | 
| protected  java.lang.String | connectionPasswordThe connection password for the server we will contact. | 
| protected  java.lang.String | connectionTimeoutThe timeout, in milliseconds, to use when trying to create a connection to the directory. | 
| protected  java.lang.String | connectionURLThe connection URL for the server we will contact. | 
| protected  javax.naming.directory.DirContext | contextThe directory context linking us to our directory server. | 
| protected  java.lang.String | contextFactoryThe JNDI context factory used to acquire our InitialContext. | 
| static java.lang.String | DEREF_ALIASESConstant that holds the name of the environment property for specifying the manner in which aliases should be dereferenced. | 
| protected  java.lang.String | derefAliasesHow aliases should be dereferenced during search operations. | 
| protected static java.lang.String | infoDescriptive information about this Realm implementation. | 
| protected static java.lang.String | nameDescriptive information about this Realm implementation. | 
| protected  java.lang.String | protocolThe protocol that will be used in the communication with the directory server. | 
| protected  java.lang.String | referralsHow should we handle referrals? | 
| protected  java.lang.String | roleBaseThe base element for role searches. | 
| protected  java.text.MessageFormat | roleFormatThe MessageFormat object associated with the current roleSearch. | 
| protected  java.lang.String | roleNameThe name of the attribute containing roles held elsewhere | 
| protected  boolean | roleNestedShould we look for nested group in order to determine roles? | 
| protected  java.lang.String | roleSearchThe message format used to select roles for a user, with "{0}" marking the spot where the distinguished name of the user goes. | 
| protected  boolean | roleSubtreeShould we search the entire subtree for matching memberships? | 
| protected  java.lang.String | userBaseThe base element for user searches. | 
| protected  java.lang.String | userPasswordThe attribute name used to retrieve the user password. | 
| protected  java.lang.String | userPatternThe message format used to form the distinguished name of a user, with "{0}" marking the spot where the specified username goes. | 
| protected  java.lang.String[] | userPatternArrayA string of LDAP user patterns or paths, ":"-separated These will be used to form the distinguished name of a user, with "{0}" marking the spot where the specified username goes. | 
| protected  java.text.MessageFormat[] | userPatternFormatArrayAn array of MessageFormat objects associated with the current userPatternArray. | 
| protected  java.lang.String | userRoleNameThe name of an attribute in the user's entry containing roles for that user | 
| protected  java.lang.String | userSearchThe message format used to search for a user, with "{0}" marking the spot where the username goes. | 
| protected  java.text.MessageFormat | userSearchFormatThe MessageFormat object associated with the current userSearch. | 
| protected  boolean | userSubtreeShould we search the entire subtree for matching users? | 
| Fields inherited from class org.apache.catalina.realm.RealmBase | 
|---|
| allRolesMode, container, containerLog, controller, digest, digestEncoding, domain, host, initialized, lifecycle, md, md5Encoder, md5Helper, mserver, oname, path, realmPath, sm, started, support, type, validate, x509UsernameRetriever, x509UsernameRetrieverClassName | 
| Fields inherited from interface org.apache.catalina.Lifecycle | 
|---|
| AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, DESTROY_EVENT, INIT_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT | 
| Constructor Summary | |
|---|---|
| JNDIRealm() | |
| Method Summary | |
|---|---|
|  java.security.Principal | authenticate(javax.naming.directory.DirContext context,
             java.lang.String username,
             java.lang.String credentials)Return the Principal associated with the specified username and credentials, if there is one; otherwise return null. | 
|  java.security.Principal | authenticate(java.lang.String username,
             java.lang.String credentials)Return the Principal associated with the specified username and credentials, if there is one; otherwise return null. | 
| protected  boolean | bindAsUser(javax.naming.directory.DirContext context,
           JNDIRealm.User user,
           java.lang.String credentials)Check credentials by binding to the directory as the user | 
| protected  boolean | checkCredentials(javax.naming.directory.DirContext context,
                 JNDIRealm.User user,
                 java.lang.String credentials)Check whether the given User can be authenticated with the given credentials. | 
| protected  void | close(javax.naming.directory.DirContext context)Close any open connection to the directory server for this Realm. | 
| protected  boolean | compareCredentials(javax.naming.directory.DirContext context,
                   JNDIRealm.User info,
                   java.lang.String credentials)Check whether the credentials presented by the user match those retrieved from the directory. | 
| protected  java.lang.String | doRFC2254Encoding(java.lang.String inString)Given an LDAP search string, returns the string with certain characters escaped according to RFC 2254 guidelines. | 
|  boolean | getAdCompat()Returns the current settings for handling PartialResultExceptions | 
|  java.lang.String | getAlternateURL()Getter for property alternateURL. | 
|  java.lang.String | getAuthentication()Return the type of authentication to use. | 
|  java.lang.String | getCommonRole()Return the common role | 
|  java.lang.String | getConnectionName()Return the connection username for this Realm. | 
|  java.lang.String | getConnectionPassword()Return the connection password for this Realm. | 
|  java.lang.String | getConnectionTimeout()Return the connection timeout. | 
|  java.lang.String | getConnectionURL()Return the connection URL for this Realm. | 
|  java.lang.String | getContextFactory()Return the JNDI context factory for this Realm. | 
|  java.lang.String | getDerefAliases()Return the derefAliases setting to be used. | 
| protected  java.util.Hashtable<java.lang.String,java.lang.String> | getDirectoryContextEnvironment()Create our directory context configuration. | 
| protected  java.lang.String | getDistinguishedName(javax.naming.directory.DirContext context,
                     java.lang.String base,
                     javax.naming.directory.SearchResult result)Returns the distinguished name of a search result. | 
|  java.lang.String | getInfo()Return descriptive information about this Realm implementation and the corresponding version number, in the format <description>/<version>. | 
| protected  java.lang.String | getName()Return a short name for this Realm implementation. | 
| protected  java.lang.String | getPassword(java.lang.String username)Return the password associated with the given principal's user name. | 
| protected  java.security.Principal | getPrincipal(javax.naming.directory.DirContext context,
             java.lang.String username)Return the Principal associated with the given user name. | 
| protected  java.security.Principal | getPrincipal(java.lang.String username)Return the Principal associated with the given user name. | 
|  java.lang.String | getProtocol()Return the protocol to be used. | 
|  java.lang.String | getReferrals()Returns the current settings for handling JNDI referrals. | 
|  java.lang.String | getRoleBase()Return the base element for role searches. | 
|  java.lang.String | getRoleName()Return the role name attribute name for this Realm. | 
|  boolean | getRoleNested()Return the "The nested group search flag" flag. | 
| protected  java.util.List<java.lang.String> | getRoles(javax.naming.directory.DirContext context,
         JNDIRealm.User user)Return a List of roles associated with the given User. | 
|  java.lang.String | getRoleSearch()Return the message format pattern for selecting roles in this Realm. | 
|  boolean | getRoleSubtree()Return the "search subtree for roles" flag. | 
| protected  JNDIRealm.User | getUser(javax.naming.directory.DirContext context,
        java.lang.String username)Return a User object containing information about the user with the specified username, if found in the directory; otherwise return null. | 
| protected  JNDIRealm.User | getUser(javax.naming.directory.DirContext context,
        java.lang.String username,
        java.lang.String credentials)Return a User object containing information about the user with the specified username, if found in the directory; otherwise return null. | 
| protected  JNDIRealm.User | getUser(javax.naming.directory.DirContext context,
        java.lang.String username,
        java.lang.String credentials,
        int curUserPattern)Return a User object containing information about the user with the specified username, if found in the directory; otherwise return null. | 
|  java.lang.String | getUserBase()Return the base element for user searches. | 
| protected  JNDIRealm.User | getUserByPattern(javax.naming.directory.DirContext context,
                 java.lang.String username,
                 java.lang.String[] attrIds,
                 java.lang.String dn)Use the distinguished name to locate the directory entry for the user with the specified username and return a User object; otherwise return null. | 
| protected  JNDIRealm.User | getUserByPattern(javax.naming.directory.DirContext context,
                 java.lang.String username,
                 java.lang.String credentials,
                 java.lang.String[] attrIds,
                 int curUserPattern)Use the UserPatternconfiguration attribute to
 locate the directory entry for the user with the specified
 username and return a User object; otherwise returnnull. | 
| protected  JNDIRealm.User | getUserBySearch(javax.naming.directory.DirContext context,
                java.lang.String username,
                java.lang.String[] attrIds)Search the directory to return a User object containing information about the user with the specified username, if found in the directory; otherwise return null. | 
|  java.lang.String | getUserPassword()Return the password attribute used to retrieve the user password. | 
|  java.lang.String | getUserPattern()Return the message format pattern for selecting users in this Realm. | 
|  java.lang.String | getUserRoleName()Return the user role name attribute name for this Realm. | 
|  java.lang.String | getUserSearch()Return the message format pattern for selecting users in this Realm. | 
|  boolean | getUserSubtree()Return the "search subtree for users" flag. | 
| protected  javax.naming.directory.DirContext | open()Open (if necessary) and return a connection to the configured directory server for this Realm. | 
| protected  java.lang.String[] | parseUserPatternString(java.lang.String userPatternString)Given a string containing LDAP patterns for user locations (separated by parentheses in a pseudo-LDAP search string format - "(location1)(location2)", returns an array of those paths. | 
| protected  void | release(javax.naming.directory.DirContext context)Release our use of this connection so that it can be recycled. | 
|  void | setAdCompat(boolean adCompat)How do we handle PartialResultExceptions? | 
|  void | setAlternateURL(java.lang.String alternateURL)Setter for property alternateURL. | 
|  void | setAuthentication(java.lang.String authentication)Set the type of authentication to use. | 
|  void | setCommonRole(java.lang.String commonRole)Set the common role | 
|  void | setConnectionName(java.lang.String connectionName)Set the connection username for this Realm. | 
|  void | setConnectionPassword(java.lang.String connectionPassword)Set the connection password for this Realm. | 
|  void | setConnectionTimeout(java.lang.String timeout)Set the connection timeout. | 
|  void | setConnectionURL(java.lang.String connectionURL)Set the connection URL for this Realm. | 
|  void | setContextFactory(java.lang.String contextFactory)Set the JNDI context factory for this Realm. | 
|  void | setDerefAliases(java.lang.String derefAliases)Set the value for derefAliases to be used when searching the directory. | 
|  void | setProtocol(java.lang.String protocol)Set the protocol for this Realm. | 
|  void | setReferrals(java.lang.String referrals)How do we handle JNDI referrals? | 
|  void | setRoleBase(java.lang.String roleBase)Set the base element for role searches. | 
|  void | setRoleName(java.lang.String roleName)Set the role name attribute name for this Realm. | 
|  void | setRoleNested(boolean roleNested)Set the "search subtree for roles" flag. | 
|  void | setRoleSearch(java.lang.String roleSearch)Set the message format pattern for selecting roles in this Realm. | 
|  void | setRoleSubtree(boolean roleSubtree)Set the "search subtree for roles" flag. | 
|  void | setUserBase(java.lang.String userBase)Set the base element for user searches. | 
|  void | setUserPassword(java.lang.String userPassword)Set the password attribute used to retrieve the user password. | 
|  void | setUserPattern(java.lang.String userPattern)Set the message format pattern for selecting users in this Realm. | 
|  void | setUserRoleName(java.lang.String userRoleName)Set the user role name attribute name for this Realm. | 
|  void | setUserSearch(java.lang.String userSearch)Set the message format pattern for selecting users in this Realm. | 
|  void | setUserSubtree(boolean userSubtree)Set the "search subtree for users" flag. | 
|  void | start()Prepare for active use of the public methods of this Component. | 
|  void | stop()Gracefully shut down active use of the public methods of this Component. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
protected java.lang.String authentication
protected java.lang.String connectionName
protected java.lang.String connectionPassword
protected java.lang.String connectionURL
protected javax.naming.directory.DirContext context
protected java.lang.String contextFactory
protected java.lang.String derefAliases
public static final java.lang.String DEREF_ALIASES
protected static final java.lang.String info
protected static final java.lang.String name
protected java.lang.String protocol
protected boolean adCompat
protected java.lang.String referrals
protected java.lang.String userBase
protected java.lang.String userSearch
protected java.text.MessageFormat userSearchFormat
userSearch.
protected boolean userSubtree
protected java.lang.String userPassword
protected java.lang.String[] userPatternArray
protected java.lang.String userPattern
protected java.text.MessageFormat[] userPatternFormatArray
userPatternArray.
protected java.lang.String roleBase
protected java.text.MessageFormat roleFormat
roleSearch.
protected java.lang.String userRoleName
protected java.lang.String roleName
protected java.lang.String roleSearch
protected boolean roleSubtree
protected boolean roleNested
protected java.lang.String alternateURL
protected int connectionAttempt
protected java.lang.String commonRole
protected java.lang.String connectionTimeout
| Constructor Detail | 
|---|
public JNDIRealm()
| Method Detail | 
|---|
public java.lang.String getAuthentication()
public void setAuthentication(java.lang.String authentication)
authentication - The authenticationpublic java.lang.String getConnectionName()
public void setConnectionName(java.lang.String connectionName)
connectionName - The new connection usernamepublic java.lang.String getConnectionPassword()
public void setConnectionPassword(java.lang.String connectionPassword)
connectionPassword - The new connection passwordpublic java.lang.String getConnectionURL()
public void setConnectionURL(java.lang.String connectionURL)
connectionURL - The new connection URLpublic java.lang.String getContextFactory()
public void setContextFactory(java.lang.String contextFactory)
contextFactory - The new context factorypublic java.lang.String getDerefAliases()
public void setDerefAliases(java.lang.String derefAliases)
derefAliases - New value of property derefAliases.public java.lang.String getProtocol()
public void setProtocol(java.lang.String protocol)
protocol - The new protocol.public boolean getAdCompat()
public void setAdCompat(boolean adCompat)
public java.lang.String getReferrals()
public void setReferrals(java.lang.String referrals)
public java.lang.String getUserBase()
public void setUserBase(java.lang.String userBase)
userBase - The new base elementpublic java.lang.String getUserSearch()
public void setUserSearch(java.lang.String userSearch)
userSearch - The new user search patternpublic boolean getUserSubtree()
public void setUserSubtree(boolean userSubtree)
userSubtree - The new search flagpublic java.lang.String getUserRoleName()
public void setUserRoleName(java.lang.String userRoleName)
userRoleName - The new userRole name attribute namepublic java.lang.String getRoleBase()
public void setRoleBase(java.lang.String roleBase)
roleBase - The new base elementpublic java.lang.String getRoleName()
public void setRoleName(java.lang.String roleName)
roleName - The new role name attribute namepublic java.lang.String getRoleSearch()
public void setRoleSearch(java.lang.String roleSearch)
roleSearch - The new role search patternpublic boolean getRoleSubtree()
public void setRoleSubtree(boolean roleSubtree)
roleSubtree - The new search flagpublic boolean getRoleNested()
public void setRoleNested(boolean roleNested)
roleNested - The nested group search flagpublic java.lang.String getUserPassword()
public void setUserPassword(java.lang.String userPassword)
userPassword - The new password attributepublic java.lang.String getUserPattern()
public void setUserPattern(java.lang.String userPattern)
userPattern - The new user patternpublic java.lang.String getAlternateURL()
public void setAlternateURL(java.lang.String alternateURL)
alternateURL - New value of property alternateURL.public java.lang.String getCommonRole()
public void setCommonRole(java.lang.String commonRole)
commonRole - The common rolepublic java.lang.String getConnectionTimeout()
public void setConnectionTimeout(java.lang.String timeout)
timeout - The new connection timeoutpublic java.lang.String getInfo()
<description>/<version>.
getInfo in interface RealmgetInfo in class RealmBase
public java.security.Principal authenticate(java.lang.String username,
                                            java.lang.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 Realmauthenticate in class RealmBaseusername - Username of the Principal to look upcredentials - Password or other credentials to use in
  authenticating this username
public java.security.Principal authenticate(javax.naming.directory.DirContext context,
                                            java.lang.String username,
                                            java.lang.String credentials)
                                     throws javax.naming.NamingException
null.
context - The directory contextusername - Username of the Principal to look upcredentials - Password or other credentials to use in
  authenticating this username
javax.naming.NamingException - if a directory server error occurs
protected JNDIRealm.User getUser(javax.naming.directory.DirContext context,
                                 java.lang.String username)
                          throws javax.naming.NamingException
null.
context - The directory contextusername - Username to be looked up
javax.naming.NamingException - if a directory server error occursgetUser(DirContext, String, String, int)
protected JNDIRealm.User getUser(javax.naming.directory.DirContext context,
                                 java.lang.String username,
                                 java.lang.String credentials)
                          throws javax.naming.NamingException
null.
context - The directory contextusername - Username to be looked upcredentials - User credentials (optional)
javax.naming.NamingException - if a directory server error occursgetUser(DirContext, String, String, int)
protected JNDIRealm.User getUser(javax.naming.directory.DirContext context,
                                 java.lang.String username,
                                 java.lang.String credentials,
                                 int curUserPattern)
                          throws javax.naming.NamingException
null.
 If the userPassword configuration attribute is
 specified, the value of that attribute is retrieved from the
 user's directory entry. If the userRoleName
 configuration attribute is specified, all values of that
 attribute are retrieved from the directory entry.
context - The directory contextusername - Username to be looked upcredentials - User credentials (optional)curUserPattern - Index into userPatternFormatArray
javax.naming.NamingException - if a directory server error occurs
protected JNDIRealm.User getUserByPattern(javax.naming.directory.DirContext context,
                                          java.lang.String username,
                                          java.lang.String[] attrIds,
                                          java.lang.String dn)
                                   throws javax.naming.NamingException
null.
context - The directory contextusername - The usernameattrIds - String[]containing names of attributes todn - Distinguished name of the user
 retrieve.
javax.naming.NamingException - if a directory server error occurs
protected JNDIRealm.User getUserByPattern(javax.naming.directory.DirContext context,
                                          java.lang.String username,
                                          java.lang.String credentials,
                                          java.lang.String[] attrIds,
                                          int curUserPattern)
                                   throws javax.naming.NamingException
UserPattern configuration attribute to
 locate the directory entry for the user with the specified
 username and return a User object; otherwise return
 null.
context - The directory contextusername - The usernamecredentials - User credentials (optional)attrIds - String[]containing names of attributes tocurUserPattern - Index into userPatternFormatArray
javax.naming.NamingException - if a directory server error occursgetUserByPattern(DirContext, String, String[], String)
protected JNDIRealm.User getUserBySearch(javax.naming.directory.DirContext context,
                                         java.lang.String username,
                                         java.lang.String[] attrIds)
                                  throws javax.naming.NamingException
null.
context - The directory contextusername - The usernameattrIds - String[]containing names of attributes to retrieve.
javax.naming.NamingException - if a directory server error occurs
protected boolean checkCredentials(javax.naming.directory.DirContext context,
                                   JNDIRealm.User user,
                                   java.lang.String credentials)
                            throws javax.naming.NamingException
userPassword
 configuration attribute is specified, the credentials
 previously retrieved from the directory are compared explicitly
 with those presented by the user. Otherwise the presented
 credentials are checked by binding to the directory as the
 user.
context - The directory contextuser - The User to be authenticatedcredentials - The credentials presented by the user
javax.naming.NamingException - if a directory server error occurs
protected boolean compareCredentials(javax.naming.directory.DirContext context,
                                     JNDIRealm.User info,
                                     java.lang.String credentials)
                              throws javax.naming.NamingException
context - The directory contextinfo - The User to be authenticatedcredentials - Authentication credentials
javax.naming.NamingException - if a directory server error occurs
protected boolean bindAsUser(javax.naming.directory.DirContext context,
                             JNDIRealm.User user,
                             java.lang.String credentials)
                      throws javax.naming.NamingException
context - The directory contextuser - The User to be authenticatedcredentials - Authentication credentials
javax.naming.NamingException - if a directory server error occurs
protected java.util.List<java.lang.String> getRoles(javax.naming.directory.DirContext context,
                                                    JNDIRealm.User user)
                                             throws javax.naming.NamingException
context - The directory context we are searchinguser - The User to be checked
javax.naming.NamingException - if a directory server error occursprotected void close(javax.naming.directory.DirContext context)
context - The directory context to be closedprotected java.lang.String getName()
getName in class RealmBaseprotected java.lang.String getPassword(java.lang.String username)
getPassword in class RealmBaseprotected java.security.Principal getPrincipal(java.lang.String username)
getPrincipal in class RealmBase
protected java.security.Principal getPrincipal(javax.naming.directory.DirContext context,
                                               java.lang.String username)
                                        throws javax.naming.NamingException
javax.naming.NamingException
protected javax.naming.directory.DirContext open()
                                          throws javax.naming.NamingException
javax.naming.NamingException - if a directory server error occursprotected java.util.Hashtable<java.lang.String,java.lang.String> getDirectoryContextEnvironment()
protected void release(javax.naming.directory.DirContext context)
context - The directory context to release
public void start()
           throws LifecycleException
start in interface Lifecyclestart in class RealmBaseLifecycleException - if this component detects a fatal error
  that prevents it from being started
public void stop()
          throws LifecycleException
stop in interface Lifecyclestop in class RealmBaseLifecycleException - if this component detects a fatal error
  that needs to be reportedprotected java.lang.String[] parseUserPatternString(java.lang.String userPatternString)
userPatternString - - a string LDAP search paths surrounded by
 parenthesesprotected java.lang.String doRFC2254Encoding(java.lang.String inString)
inString - string to escape according to RFC 2254 guidelines
protected java.lang.String getDistinguishedName(javax.naming.directory.DirContext context,
                                                java.lang.String base,
                                                javax.naming.directory.SearchResult result)
                                         throws javax.naming.NamingException
context - Our DirContextbase - The base DNresult - The search result
javax.naming.NamingException| 
 | Apache Tomcat 6.0.53 | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||