Package org.apache.catalina.realm
Class GenericPrincipal
- java.lang.Object
- 
- org.apache.catalina.realm.GenericPrincipal
 
- 
- All Implemented Interfaces:
- Serializable,- Principal,- TomcatPrincipal
 - Direct Known Subclasses:
- UserDatabaseRealm.UserDatabasePrincipal
 
 public class GenericPrincipal extends Object implements TomcatPrincipal, Serializable Generic implementation of java.security.Principal that is available for use byRealmimplementations.- Author:
- Craig R. McClanahan
- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected GSSCredentialgssCredentialThe user's delegated credentials.protected LoginContextloginContextThe JAAS LoginContext, if any, used to authenticate this Principal.protected StringnameThe username of the user represented by this Principal.protected String[]rolesThe set of roles associated with this user.protected PrincipaluserPrincipalThe authenticated Principal to be exposed to applications.
 - 
Constructor SummaryConstructors Constructor Description GenericPrincipal(String name)Construct a new Principal, associated with the specified Realm, for the specified username, with no roles.GenericPrincipal(String name, String password, List<String> roles)Deprecated.This method will be removed in Tomcat 11 onwardsGenericPrincipal(String name, String password, List<String> roles, Principal userPrincipal)Deprecated.This method will be removed in Tomcat 11 onwardsGenericPrincipal(String name, String password, List<String> roles, Principal userPrincipal, LoginContext loginContext)Deprecated.This method will be removed in Tomcat 11 onwardsGenericPrincipal(String name, String password, List<String> roles, Principal userPrincipal, LoginContext loginContext, GSSCredential gssCredential)Deprecated.This method will be removed in Tomcat 11 onwardsGenericPrincipal(String name, List<String> roles)Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).GenericPrincipal(String name, List<String> roles, Principal userPrincipal)Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).GenericPrincipal(String name, List<String> roles, Principal userPrincipal, LoginContext loginContext)Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).GenericPrincipal(String name, List<String> roles, Principal userPrincipal, LoginContext loginContext, GSSCredential gssCredential)Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description GSSCredentialgetGssCredential()StringgetName()String[]getRoles()PrincipalgetUserPrincipal()booleanhasRole(String role)Does the user represented by this Principal possess the specified role?voidlogout()Calls logout, if necessary, on any associated JAASLoginContext and/or GSSContext.protected voidsetGssCredential(GSSCredential gssCredential)StringtoString()Return a String representation of this object, which exposes only information that should be public.
 
- 
- 
- 
Field Detail- 
nameprotected final String name The username of the user represented by this Principal.
 - 
rolesprotected final String[] roles The set of roles associated with this user.
 - 
userPrincipalprotected final Principal userPrincipal The authenticated Principal to be exposed to applications.
 - 
loginContextprotected final transient LoginContext loginContext The JAAS LoginContext, if any, used to authenticate this Principal. Kept so we can call logout().
 - 
gssCredentialprotected transient GSSCredential gssCredential The user's delegated credentials.
 
- 
 - 
Constructor Detail- 
GenericPrincipalpublic GenericPrincipal(String name) Construct a new Principal, associated with the specified Realm, for the specified username, with no roles.- Parameters:
- name- The username of the user represented by this Principal
 
 - 
GenericPrincipalpublic GenericPrincipal(String name, List<String> roles) Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- roles- List of roles (must be Strings) possessed by this user
 
 - 
GenericPrincipal@Deprecated public GenericPrincipal(String name, String password, List<String> roles) Deprecated.This method will be removed in Tomcat 11 onwardsConstruct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- password- Unused
- roles- List of roles (must be Strings) possessed by this user
 
 - 
GenericPrincipalpublic GenericPrincipal(String name, List<String> roles, Principal userPrincipal) Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- roles- List of roles (must be Strings) possessed by this user
- userPrincipal- - the principal to be returned from the request getUserPrincipal call if not null; if null, this will be returned
 
 - 
GenericPrincipal@Deprecated public GenericPrincipal(String name, String password, List<String> roles, Principal userPrincipal) Deprecated.This method will be removed in Tomcat 11 onwardsConstruct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- password- Unused
- roles- List of roles (must be Strings) possessed by this user
- userPrincipal- - the principal to be returned from the request getUserPrincipal call if not null; if null, this will be returned
 
 - 
GenericPrincipalpublic GenericPrincipal(String name, List<String> roles, Principal userPrincipal, LoginContext loginContext) Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- roles- List of roles (must be Strings) possessed by this user
- userPrincipal- - the principal to be returned from the request getUserPrincipal call if not null; if null, this will be returned
- loginContext- - If provided, this will be used to log out the user at the appropriate time
 
 - 
GenericPrincipal@Deprecated public GenericPrincipal(String name, String password, List<String> roles, Principal userPrincipal, LoginContext loginContext) Deprecated.This method will be removed in Tomcat 11 onwardsConstruct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- password- Unused
- roles- List of roles (must be Strings) possessed by this user
- userPrincipal- - the principal to be returned from the request getUserPrincipal call if not null; if null, this will be returned
- loginContext- - If provided, this will be used to log out the user at the appropriate time
 
 - 
GenericPrincipalpublic GenericPrincipal(String name, List<String> roles, Principal userPrincipal, LoginContext loginContext, GSSCredential gssCredential) Construct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- roles- List of roles (must be Strings) possessed by this user
- userPrincipal- - the principal to be returned from the request getUserPrincipal call if not null; if null, this will be returned
- loginContext- - If provided, this will be used to log out the user at the appropriate time
- gssCredential- - If provided, the user's delegated credentials
 
 - 
GenericPrincipal@Deprecated public GenericPrincipal(String name, String password, List<String> roles, Principal userPrincipal, LoginContext loginContext, GSSCredential gssCredential) Deprecated.This method will be removed in Tomcat 11 onwardsConstruct a new Principal, associated with the specified Realm, for the specified username, with the specified role names (as Strings).- Parameters:
- name- The username of the user represented by this Principal
- password- Unused
- roles- List of roles (must be Strings) possessed by this user
- userPrincipal- - the principal to be returned from the request getUserPrincipal call if not null; if null, this will be returned
- loginContext- - If provided, this will be used to log out the user at the appropriate time
- gssCredential- - If provided, the user's delegated credentials
 
 
- 
 - 
Method Detail- 
getRolespublic String[] getRoles() 
 - 
getUserPrincipalpublic Principal getUserPrincipal() - Specified by:
- getUserPrincipalin interface- TomcatPrincipal
- Returns:
- The authenticated Principal to be exposed to applications.
 
 - 
getGssCredentialpublic GSSCredential getGssCredential() - Specified by:
- getGssCredentialin interface- TomcatPrincipal
- Returns:
- The user's delegated credentials.
 
 - 
setGssCredentialprotected void setGssCredential(GSSCredential gssCredential) 
 - 
hasRolepublic boolean hasRole(String role) Does the user represented by this Principal possess the specified role?- Parameters:
- role- Role to be tested
- Returns:
- trueif this Principal has been assigned the given role, otherwise- false
 
 - 
toStringpublic String toString() Return a String representation of this object, which exposes only information that should be public.
 - 
logoutpublic void logout() throws ExceptionDescription copied from interface:TomcatPrincipalCalls logout, if necessary, on any associated JAASLoginContext and/or GSSContext. May in the future be extended to cover other logout requirements.- Specified by:
- logoutin interface- TomcatPrincipal
- Throws:
- Exception- If something goes wrong with the logout. Uses Exception to allow for future expansion of this method to cover other logout mechanisms that might throw a different exception to LoginContext
 
 
- 
 
-