Class AMLoginModule
- java.lang.Object
- 
- com.sun.identity.authentication.spi.AMLoginModule
 
- 
- All Implemented Interfaces:
- LoginModule
 - Direct Known Subclasses:
- AbstractLoginModuleBinder,- AbstractPushModule,- Adaptive,- Anonymous,- Application,- AuthenticatorOATH,- Cert,- DataStore,- DeviceIdSave,- Federation,- HOTP,- HTTPBasic,- JDBC,- LDAP,- Membership,- MSISDN,- NT,- Ntlm,- OATH,- OAuth,- OpenIdConnect,- QR,- RADIUS,- ReCaptcha,- SAE,- SAML2,- Scripted,- SecurID,- WebAuthnAuthentication,- WebAuthnRegistration,- WindowsDesktopSSO,- WSSAuthModule
 
 public abstract class AMLoginModule extends Object implements LoginModule An abstract class which implements JAAS LoginModule, it provides methods to access OpenAM services and the module xml configuration.Because it is an abstract class, Login Module writers must subclass and implement init(), process(), getPrincipal() methods. The Callback[] for the Login Module is dynamically generated based on the xml module configuration. The module configuration file name must be the same as the name of the class (no package name) and have the extension .xml. Here is a sample module configuration file: <ModuleProperties moduleClass="LDAP" version="1.0" > <Callbacks length="2" order="1" timeout="60" header="LDAP Authentication" > <NameCallback> <Prompt> Enter UserId </Prompt> </NameCallback> <PasswordCallback echoPassword="false" > <Prompt> Enter Password </Prompt> </PasswordCallback> </Callbacks> <Callbacks length="3" order="2" timeout="120" header="Password Expiring Please Change" > <PasswordCallback echoPassword="false" > <Prompt> Enter Current Password </Prompt> </PasswordCallback> <PasswordCallback echoPassword="false" > <Prompt> Enter New Password </Prompt> </PasswordCallback> <PasswordCallback echoPassword="false" > <Prompt> Confirm New Password </Prompt> </PasswordCallback> </Callbacks> </ModuleProperties>Each Callbacks Element corresponds to one login state. When an authentication process is invoked, there will be Callback[] generated from user's Login Module for each state. All login state starts with 1, then module controls the login process, and decides what's the next state to go in the process() method.In the sample module configuration shown above, state one has three Callbacks, Callback[0] is for module information, Callback[1] is for user ID, Callback[2] is for user password. When the user fills in the Callbacks, those Callback[] will be sent to the process() method, where the module writer gets the submitted Callbacks, validates them and returns. If user's password is expiring, the module writer will set the next state to 2. State two has four Callbacks to request user to change password. The process() routine is again called after user submits the Callback[]. If the module writer throws an LoginException, an 'authentication failed' page will be sent to the user. If no exception is thrown, the user will be redirected to their default page. The optional 'timeout' attribute in each state is used to ensure that the user responds in a timely manner. If the time between sending the Callbacks and getting response is greater than the timeout, a timeout page will be sent. There are also optional 'html' and 'image' attribute in each state. The 'html' attribute allows the module writer to use a custom HTML page for the Login UI. The 'image' attribute allows the writer to display a custom background image on each page. When multiple states are available to the user, the Callback array from a previous state may be retrieved by using the getCallbak(int)methods. The underlying login module keeps the Callback[] from the previous states until the login process is completed.If a module writer need to substitute dynamic text in next state, the writer could use the getCallback()method to get the Callback[] for the next state, modify the output text or prompt, then callreplaceCallback()to update the Callback array. This allows a module writer to dynamically generate challenges, passwords or user IDs.Each authentication session will create a new instance of your Login Module Java class. The reference to the class will be released once the authentication session has either succeeded or failed. It is important to note that any static data or reference to any static data in your Login module must be thread-safe. For a complete sample, please refer to <install_root>/SUNWam/samples/authentication/providers 
- 
- 
Field SummaryFields Modifier and Type Field Description protected static AMResourceBundleCacheamCacheHolds handle to ResourceBundleCache to quickly get ResourceBundle for any Locale.protected AuthenticationModuleEventAuditorauditorprotected intcurrentState
 - 
Constructor SummaryConstructors Constructor Description AMLoginModule()No argument constructor forAMLoginModule.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description booleanabort()Aborts the authentication process.voidclearInfoText(int state)Clears the info text for a given callback statebooleancommit()Commit the authentication process (phase 2).voidcreateIdentity(String userName, Map userAttributes, Set userRoles)CreatesAMIdentityin the repository.voiddestroyModuleState()This method should be overridden by each login module to destroy dispensable state fields.protected voidforceCallbacksInit()AMIdentityRepositorygetAMIdentityRepository(String orgDN)ReturnsAMIdentityRepostioryhandle for an organization.StringgetAttribute(int state, int index)Returns the attribute name for the specified callback in the specified login state.protected AuthenticationAuditEntrygetAuditEntryDetail()Supply the additional detail to be logged with this module's completion event.protected Set<String>getAuthenticatedPrincipals()Returns the principals authenticated in the current authentication process or an empty set if login state is unavailable or no authenticated principals are present.intgetAuthLevel()Returns authentication level that has been set for the moduleCallback[]getCallback(int index)Returns a Callback array for a specific state.Callback[]getCallback(int index, boolean fetchOrig)Return a Callback array for a specific state.CallbackHandlergetCallbackHandler()Returns the CallbackHandler object for the module.intgetCurrentState()Returns the current state in the authentication process.intgetFailCount(AMIdentity amIdUser)Get the number of failed login attempts for a user when account locking is enabled.jakarta.servlet.http.HttpServletRequestgetHttpServletRequest()Returns theHttpServletRequestobject that initiated the call to this module.jakarta.servlet.http.HttpServletResponsegetHttpServletResponse()Returns theHttpServletResponseobject for the servlet request that initiated the call to this module.StringgetInfoText(int state, int index)Returns the info text associated with a specific callbackStringgetLocale()Returns the locale for this authentication session.protected LocalegetLoginLocale()Returns the LoginLocalefor this sessionprotected LoginStategetLoginState(String methodName)Returns the authenticationLoginStateintgetMaximumFailCount()Get the maximum number failed login attempts permitted for a user before when their account is locked out.SetgetNewUserIDs(Map attributes, int num)Returns a set of user IDs generated from the class defined in the Core Authentication Service.intgetNumberOfStates()Returns the number of authentication states for this login module.MapgetOrgProfile(String orgDN)Returns the organization attributes for specified organization.MapgetOrgServiceTemplate(String orgDN, String serviceName)Returns service template attributes defined for the specified organization.abstract PrincipalgetPrincipal()Abstract method must be implemeted by each login module to get the user PrincipalStringgetPwdKey()Returns JAAS shared state password key.StringgetRequestOrg()Returns the organization DN for this authentication session.MapgetServiceConfig(String name)Returns service configuration attributes.StringgetSessionId()Returns a unique key for this authentication session.SSOTokengetSSOSession()Returns an administration SSOToken for use the OpenAM APIs.protected Set<String>getUserAliasList()Provides the "Alias Search Attribute Name" list from the Authentication Service for the realm.StringgetUserKey()Returns JAAS shared state user key.AMUsergetUserProfile(String userDN)Deprecated.This method has been deprecated.StringgetUserSessionProperty(String name)Returns the property from the user session.Set<SSOToken>getUserSessions(String userName)Returns the set of SSOTokens for a specified uservoidincrementFailCount(String userName)Increments the fail count for the given user.abstract voidinit(Subject subject, Map sharedState, Map options)Initialize this LoginModule.voidinitialize(Subject subject, CallbackHandler callbackHandler, Map sharedState, Map options)Implements initialize() method in JAAS LoginModule class.booleanisAccountLocked(String userName)Returns true if the named account is locked out, false otherwise.booleanisDynamicProfileCreationEnabled()Checks if dynamic profile creation is enabled.booleanisRequired(int state, int index)Checks if a Callback is required to have input.booleanisSessionQuotaReached(String userName)Returns true if the user identified by the supplied username has reached their session quota.
 NBThe existing session count is exclusive of any session created as part of the running authentication processbooleanisSharedStateEnabled()Checks if shared state enabled for the module.booleanisSuperAdmin(String userDN)Checks if distinguished user name is a super admin.booleanisUseFirstPassEnabled()This method returns use first pass enabled or notbooleanisValidUserEntry(String userDN)Checks if valid user exists.booleanlogin()Implements login() method in JAAS LoginModule class.booleanlogout()Logs out a Subject.voidnullifyUsedVars()This method should be overridden by each login module to do some garbage collection work after the module process is done.abstract intprocess(Callback[] callbacks, int state)Abstract method must be implemented by each login module to control the flow of the login process.voidreplaceCallback(int state, int index, Callback callback)Replace Callback object for a specific state.voidreplaceHeader(int state, String header)Replace page header for a specific state.voidresetCallback(int state, int index)Reset a Callback instance to the original Callback for the specified state and the specified index.voidresetCurrentState()Resets the current state in the authentication processbooleansetAuthLevel(int auth_level)Sets theAuthLevelfor this session.voidsetFailureID(String userID)Sets theuserIDof user who failed authentication.voidsetForceCallbacksRead(boolean val)Sets flag to force read call backs in auth chain process.voidsetLoginFailureURL(String url)Sets the the login failure URL for the user.voidsetLoginSuccessURL(String url)Sets the the login successful URL for the user.voidsetModuleErrorTemplate(String templateName)Sets the error template for the modulevoidsetOrg(String orgDN)Sets the user organization.voidsetSharedStateEnabled(boolean val)Updates shared state for the modulevoidsetUserAttributes(Map attributeValuePairs)Sets a Map of attribute value pairs to be used when the authentication service is configured to dynamically create a user.voidsetUserSessionProperty(String name, String value)Sets a property in the user session.voidstoreUsername(String username)Stores user name into shared state map.voidstoreUsernamePasswd(String user, String passwd)Stores user name and password into shared state map.voidsubstituteHeader(int state, String header)Use this method to replace the header text from the XML file with new text.voidsubstituteInfoText(int state, int callback, String infoText)Allows you to set the info text for a specific callback.voidvalidatePassword(String userPassword)Validate password for the distinguished user, this will use validation plugin if exists to validate passwordvoidvalidateUserName(String userName, String regEx)Validates the given user name by using validation plugin if exists else it checks invalid characters in the source string.
 
- 
- 
- 
Field Detail- 
currentStateprotected int currentState 
 - 
amCacheprotected static AMResourceBundleCache amCache Holds handle to ResourceBundleCache to quickly get ResourceBundle for any Locale.
 - 
auditorprotected final AuthenticationModuleEventAuditor auditor 
 
- 
 - 
Constructor Detail- 
AMLoginModulepublic AMLoginModule() No argument constructor forAMLoginModule.
 
- 
 - 
Method Detail- 
getSSOSessionpublic SSOToken getSSOSession() throws AuthLoginException Returns an administration SSOToken for use the OpenAM APIs. NB:This is not the SSOToken that represents the user, if you wish to set/get user session properties use thesetUserSessionPropertyandgetUserSessionPropertymethod respectively.- Returns:
- An administrative SSOToken.
- Throws:
- AuthLoginException- if the authentication SSO session is null.
 
 - 
getCallbackpublic Callback[] getCallback(int index) throws AuthLoginException Returns a Callback array for a specific state.This method can be used to retrieve Callback[] for any state. All previous submitted Callback[] information are kept until the login process is completed. - Parameters:
- index- order of state
- Returns:
- Callback array for this state, return 0-length Callback array if there is no Callback defined for this state
- Throws:
- AuthLoginException- if unable to read the callbacks
 
 - 
getCallbackpublic Callback[] getCallback(int index, boolean fetchOrig) throws AuthLoginException Return a Callback array for a specific state.This method can be used to retrieve Callback[] for any state. All previous submitted Callback[] information are kept until the login process is completed. - Parameters:
- index- order of state
- fetchOrig- boolean indicating even if the callbacks for this state have been previously retrieved, get the original callbacks from AMModuleProperties, if set to "true".
- Returns:
- Callback array for this state, return 0-length Callback array if there is no Callback defined for this state
- Throws:
- AuthLoginException- if unable to read the callbacks
 
 - 
forceCallbacksInitprotected void forceCallbacksInit() throws AuthLoginException- Throws:
- AuthLoginException
 
 - 
replaceCallbackpublic void replaceCallback(int state, int index, Callback callback) throws AuthLoginExceptionReplace Callback object for a specific state.- Parameters:
- state- Order of login state
- index- Index of Callback in the Callback array to be replaced for the specified state. Here index starts with 0, i.e. 0 means the first Callback in the Callback[], 1 means the second callback.
- callback- Callback instance to be replaced
- Throws:
- AuthLoginException- if state or index is out of bound, or callback instance is null.
 
 - 
replaceHeaderpublic void replaceHeader(int state, String header) throws AuthLoginExceptionReplace page header for a specific state.- Parameters:
- state- Order of login state
- header- header messages to be replaced
- Throws:
- AuthLoginException- if state is out of bound.
 
 - 
substituteInfoTextpublic void substituteInfoText(int state, int callback, String infoText) throws AuthLoginExceptionAllows you to set the info text for a specific callback. Info Text is shown under the element in the Login page. It is used in the membership module to implement in-line feedback.- Parameters:
- state- state in which the Callback[] to be reset
- callback- the callback to associate the info text
- infoText- the infotext for the callback
- Throws:
- AuthLoginException- if state/callback is out of bounds
 
 - 
clearInfoTextpublic void clearInfoText(int state) throws AuthLoginExceptionClears the info text for a given callback state- Parameters:
- state- The state to clear all infotexts
- Throws:
- AuthLoginException- Invalid state
 
 - 
substituteHeaderpublic void substituteHeader(int state, String header) throws AuthLoginExceptionUse this method to replace the header text from the XML file with new text. This method can be used multiple times on the same state replacing text with new text each time. Useful for modules that control their own error handling.- Parameters:
- state- state state in which the Callback[] to be reset
- header- The text of the header to be replaced
- Throws:
- AuthLoginException- if state is out of bounds
 
 - 
resetCallbackpublic void resetCallback(int state, int index) throws AuthLoginExceptionReset a Callback instance to the original Callback for the specified state and the specified index. This will override change to the Callback instance by thereplaceCallback()method.- Parameters:
- state- state in which the Callback[] to be reset
- index- index order of the Callback in the Callback[], index starts with 0, i.e. 0 means first callback instance, 1 means the second callback instance.
- Throws:
- AuthLoginException- if state or index is out of bound.
 
 - 
initializepublic final void initialize(Subject subject, CallbackHandler callbackHandler, Map sharedState, Map options) Implements initialize() method in JAAS LoginModule class.The purpose of this method is to initialize Login Module, it will call the init() method implemented by user's Login Module to do initialization. This is a final method. - Specified by:
- initializein interface- LoginModule
- Parameters:
- subject- - the Subject to be authenticated.
- callbackHandler- - a CallbackHandler for communicating with the end user (prompting for usernames and passwords, for example).
- sharedState- - state shared with other configured LoginModules.
- options- - options specified in the login Configuration for this particular LoginModule.
 
 - 
initpublic abstract void init(Subject subject, Map sharedState, Map options) Initialize this LoginModule.This is an abstract method, must be implemented by user's Login Module to initialize this LoginModule with the relevant information. If this LoginModule does not understand any of the data stored in sharedState or options parameters, they can be ignored. - Parameters:
- subject- - the Subject to be authenticated.
- sharedState- - state shared with other configured LoginModules.
- options- - options specified in the login Configuration for this particular LoginModule. It contains all the global and organization attribute configuration for this module. The key of the map is the attribute name (e.g.- iplanet-am-auth-ldap-server) as String, the value is the value of the corresponding attribute as Set.
 
 - 
processpublic abstract int process(Callback[] callbacks, int state) throws LoginException Abstract method must be implemented by each login module to control the flow of the login process.This method takes an array of sbumitted Callback, process them and decide the order of next state to go. Return -1 if the login is successful, return 0 if the LoginModule should be ignored. - Parameters:
- callbacks- Callback[] for this Login state
- state- Order of state. State order starts with 1.
- Returns:
- order of next state. return -1 if authentication is successful, return 0 if the LoginModule should be ignored.
- Throws:
- LoginException- if login fails.
 
 - 
getPrincipalpublic abstract Principal getPrincipal() Abstract method must be implemeted by each login module to get the user Principal- Returns:
- Principal
 
 - 
destroyModuleStatepublic void destroyModuleState() This method should be overridden by each login module to destroy dispensable state fields.
 - 
nullifyUsedVarspublic void nullifyUsedVars() This method should be overridden by each login module to do some garbage collection work after the module process is done. Typically those class wide global variables that will not be used again until a logout call should be nullified.
 - 
loginpublic final boolean login() throws AuthLoginExceptionImplements login() method in JAAS LoginModule class.This method is responsible for retrieving corresponding Callback[] for current state, send as requirement to user, get the submitted Callback[], call the process() method. The process() method will decide the next action based on those submitted Callback[]. This method is final. - Specified by:
- loginin interface- LoginModule
- Returns:
- trueif the authentication succeeded, or- falseif this LoginModule should be ignored.
- Throws:
- AuthLoginException- - if the authentication fails
 
 - 
getAuthLevelpublic int getAuthLevel() Returns authentication level that has been set for the module- Returns:
- authentication level of this authentication session
 
 - 
setAuthLevelpublic boolean setAuthLevel(int auth_level) Sets theAuthLevelfor this session. The authentication level being set cannot be downgraded below that set by the module configuration.- Parameters:
- auth_level- authentication level string to be set
- Returns:
- trueif setting is successful,- falseotherwise
 
 - 
getCurrentStatepublic int getCurrentState() Returns the current state in the authentication process.- Returns:
- the current state in the authentication process.
 
 - 
resetCurrentStatepublic void resetCurrentState() Resets the current state in the authentication process- Parameters:
- state-
 
 - 
getHttpServletRequestpublic jakarta.servlet.http.HttpServletRequest getHttpServletRequest() Returns theHttpServletRequestobject that initiated the call to this module.- Returns:
- HttpServletRequestfor this request, returns null if the- HttpServletRequestobject could not be obtained.
 
 - 
getLoginStateprotected LoginState getLoginState(String methodName) throws AuthLoginException Returns the authenticationLoginState- Parameters:
- methodName- Name of the required methd in- LoginStateobject
- Returns:
- com.sun.identity.authentication.service.LoginStatefor this authentication method.
- Throws:
- AuthLoginException- if fails to get the Login state
 
 - 
getLoginLocaleprotected Locale getLoginLocale() Returns the LoginLocalefor this session- Returns:
- Localeused for localizing text
 
 - 
getHttpServletResponsepublic jakarta.servlet.http.HttpServletResponse getHttpServletResponse() Returns theHttpServletResponseobject for the servlet request that initiated the call to this module. The servlet response object will be the response to theHttpServletRequestreceived by the authentication module.- Returns:
- HttpServletResponsefor this request, returns null if the- HttpServletResponseobject could not be obtained.
 
 - 
getCallbackHandlerpublic CallbackHandler getCallbackHandler() Returns the CallbackHandler object for the module. This method will be used internally.- Returns:
- CallbackHandler for this request, returns null if the CallbackHandler object could not be obtained.
 
 - 
getLocalepublic String getLocale() throws AuthLoginException Returns the locale for this authentication session.- Returns:
- java.util.Localelocale for this authentication session.
- Throws:
- AuthLoginException- if problem in accessing the locale.
 
 - 
getNumberOfStatespublic int getNumberOfStates() Returns the number of authentication states for this login module.- Returns:
- the number of authentication states for this login module.
 
 - 
getRequestOrgpublic String getRequestOrg() Returns the organization DN for this authentication session.- Returns:
- organization DN.
 
 - 
getSessionIdpublic String getSessionId() Returns a unique key for this authentication session. This key will be unique throughout an entire Web browser session.- Returns:
- null is unable to get the key,
 
 - 
getOrgProfilepublic Map getOrgProfile(String orgDN) throws AuthLoginException Returns the organization attributes for specified organization.- Parameters:
- orgDN- Requested organization DN.
- Returns:
- Map that contains all attribute key/value pairs defined in the organization.
- Throws:
- AuthLoginException- if cannot get organization profile.
 
 - 
getOrgServiceTemplatepublic Map getOrgServiceTemplate(String orgDN, String serviceName) throws AuthLoginException Returns service template attributes defined for the specified organization.- Parameters:
- orgDN- Organization DN.
- serviceName- Requested service name.
- Returns:
- Map that contains all attribute key/value pairs defined in the organization service template.
- Throws:
- AuthLoginException- if cannot get organization service template.
 
 - 
isDynamicProfileCreationEnabledpublic boolean isDynamicProfileCreationEnabled() Checks if dynamic profile creation is enabled.- Returns:
- trueif dynamic profile creation is enabled.
 
 - 
getServiceConfigpublic Map getServiceConfig(String name) throws AuthLoginException Returns service configuration attributes.- Parameters:
- name- Requested service name.
- Returns:
- Map that contains all attribute key/value pairs defined in the service configuration.
- Throws:
- AuthLoginException- if error in accessing the service schema.
 
 - 
getUserProfilepublic AMUser getUserProfile(String userDN) throws AuthLoginException Deprecated.This method has been deprecated. Please use the IdRepo API's to get the AMIdentity object for the user. More information on how to use the Identity Repository APIs is available in the "Customizing Identity Data Storage" chapter of the OpenAM Developer's Guide.Returns the user profile for the user specified. This method may only be called in the validate() method.- Parameters:
- userDN- distinguished name os user.
- Returns:
- AMUserobject for the user's distinguished name.
- Throws:
- AuthLoginException- if it fails to get the user profile for- userDN.
 
 - 
getUserSessionPropertypublic String getUserSessionProperty(String name) throws AuthLoginException Returns the property from the user session. If the session is being force upgraded then set on the old session otherwise set on the current session.- Parameters:
- name- The property name.
- Returns:
- The property value.
- Throws:
- AuthLoginException- if the user session is invalid.
 
 - 
setUserSessionPropertypublic void setUserSessionProperty(String name, String value) throws AuthLoginException Sets a property in the user session. If the session is being force upgraded then set on the old session otherwise set on the current session.- Parameters:
- name- The property name.
- value- The property value.
- Throws:
- AuthLoginException- if the user session is invalid.
 
 - 
getNewUserIDspublic Set getNewUserIDs(Map attributes, int num) throws AuthLoginException Returns a set of user IDs generated from the class defined in the Core Authentication Service. Returns null if the attributeiplanet-am-auth-username-generator-enabledis set to false.- Parameters:
- attributes- the keys in the- Mapcontains the attribute names and their corresponding values in the- Mapis a- Setthat contains the values for the attribute
- num- the maximum number of returned user IDs; 0 means there is no limit
- Returns:
- a set of auto-generated user IDs
- Throws:
- AuthLoginException- if the class instantiation failed
 
 - 
setLoginFailureURLpublic void setLoginFailureURL(String url) throws AuthLoginException Sets the the login failure URL for the user. This method does not change the URL in the user's profile. When the user authenticates failed, this URL will be used by the authentication for the redirect.- Parameters:
- url- URL to go when authentication failed.
- Throws:
- AuthLoginException- if unable to set the URL.
 
 - 
setModuleErrorTemplatepublic void setModuleErrorTemplate(String templateName) throws AuthLoginException Sets the error template for the module- Parameters:
- templateName- the error template for the module
- Throws:
- AuthLoginException- when unable to set the template
 
 - 
setLoginSuccessURLpublic void setLoginSuccessURL(String url) throws AuthLoginException Sets the the login successful URL for the user. This method does not change the URL in the user's profile. When the user authenticates successfully, this URL will be used by the authentication for the redirect.- Parameters:
- url-- URLto go when authentication is successful.
- Throws:
- AuthLoginException- if unable to set the URL.
 
 - 
setOrgpublic void setOrg(String orgDN) throws AuthLoginException Sets the user organization. This method should only be called when the user authenticates successfully. It allows the user authentication module to decide in which domain the user profile should be created.- Parameters:
- orgDN- The organization DN.
- Throws:
- AuthLoginException
 
 - 
isRequiredpublic boolean isRequired(int state, int index)Checks if a Callback is required to have input.- Parameters:
- state- Order of state.
- index- Order of the Callback in the Callback[], the index. starts with 0.
- Returns:
- trueif the callback corresponding to the number in the specified state is required to have value,- falseotherwise
 
 - 
getInfoTextpublic String getInfoText(int state, int index) Returns the info text associated with a specific callback- Parameters:
- state- The state to fetch the info text
- index- The callback to fetch the info text
- Returns:
- The info text
 
 - 
getAttributepublic String getAttribute(int state, int index) Returns the attribute name for the specified callback in the specified login state.- Parameters:
- state- Order of state
- index- Order of the Callback in the Callback[], the index starts with 0.
- Returns:
- Name of the attribute, empty string will be returned if the attribute is not defined.
 
 - 
abortpublic final boolean abort() throws AuthLoginExceptionAborts the authentication process.This JAAS LoginModule method must be implemented by user's module. This method is called if the overall authentication failed. (the relevant REQUIRED, REQUISITE, SUFFICIENT and OPTIONAL LoginModules did not succeed). If this LoginModule's own authentication attempt succeeded (checked by retrieving the private state saved by the login method), then this method cleans up any state that was originally saved. - Specified by:
- abortin interface- LoginModule
- Returns:
- trueif this method succeeded,- falseif this LoginModule should be ignored.
- Throws:
- AuthLoginException- if the abort fails
- See Also:
- LoginModule.abort()
 
 - 
commitpublic final boolean commit() throws AuthLoginExceptionCommit the authentication process (phase 2).This JAAS LoginModule method must be implemented by user's module. This method is called if the overall authentication succeeded (the relevant REQUIRED, REQUISITE, SUFFICIENT and OPTIONAL LoginModules succeeded). If this LoginModule's own authentication attempt succeeded (checked by retrieving the private state saved by the login method), then this method associates relevant Principals and Credentials with the Subject located in the LoginModule. If this LoginModule's own authentication attempted failed, then this method removes/destroys any state that was originally saved. - Specified by:
- commitin interface- LoginModule
- Returns:
- trueif this method succeeded, or- falseif this- LoginModuleshould be ignored.
- Throws:
- AuthLoginException- if the commit fails
- See Also:
- LoginModule.commit()
 
 - 
logoutpublic final boolean logout() throws AuthLoginExceptionLogs out a Subject.This JAAS LoginModule method must be implemented by user's module. An implementation of this method might remove/destroy a Subject's Principals and Credentials. - Specified by:
- logoutin interface- LoginModule
- Returns:
- trueif this method succeeded, or- falseif this LoginModule should be ignored.
- Throws:
- AuthLoginException- if the logout fails
- See Also:
- LoginModule.logout()
 
 - 
setFailureIDpublic void setFailureID(String userID) Sets theuserIDof user who failed authentication. ThisuserIDwill be used to log failed authentication in the OpenSSO error logs.- Parameters:
- userID- user name of user who failed authentication.
 
 - 
setUserAttributespublic void setUserAttributes(Map attributeValuePairs) Sets a Map of attribute value pairs to be used when the authentication service is configured to dynamically create a user.- Parameters:
- attributeValuePairs- A map containing the attributes and its values. The key is the attribute name and the value is a Set of values.
 
 - 
validateUserNamepublic void validateUserName(String userName, String regEx) throws UserNamePasswordValidationException Validates the given user name by using validation plugin if exists else it checks invalid characters in the source string.- Parameters:
- userName- source string which should be validated.
- regEx- the pattern for which to search.
- Throws:
- UserNamePasswordValidationException- if user name is invalid.
 
 - 
isValidUserEntrypublic boolean isValidUserEntry(String userDN) Checks if valid user exists.- Parameters:
- userDN- the distinguished name of the user.
- Returns:
- trueif user exists,- falseotherwise
 
 - 
isSuperAdminpublic boolean isSuperAdmin(String userDN) Checks if distinguished user name is a super admin.- Parameters:
- userDN- the distinguished name of the user.
- Returns:
- trueif distinguished user name is a super admin.
 
 - 
validatePasswordpublic void validatePassword(String userPassword) throws UserNamePasswordValidationException Validate password for the distinguished user, this will use validation plugin if exists to validate password- Parameters:
- userPassword- source string which should be validated.
- Throws:
- UserNamePasswordValidationException- if user password is invalid.
 
 - 
getUserKeypublic String getUserKey() Returns JAAS shared state user key.- Returns:
- user key.
 
 - 
getPwdKeypublic String getPwdKey() Returns JAAS shared state password key.- Returns:
- password key
 
 - 
storeUsernamepublic void storeUsername(String username) Stores user name into shared state map. This method should be called after successful authentication by each individual module if a username was supplied by that module.- Parameters:
- username- user name.
 
 - 
storeUsernamePasswdpublic void storeUsernamePasswd(String user, String passwd) Stores user name and password into shared state map. This method should be called after successful authentication by each individual module if both a username and a password were supplied in that module.- Parameters:
- user- user name.
- passwd- user password.
 
 - 
isSharedStateEnabledpublic boolean isSharedStateEnabled() Checks if shared state enabled for the module.- Returns:
- trueif shared state enabled for the module.
 
 - 
setSharedStateEnabledpublic void setSharedStateEnabled(boolean val) Updates shared state for the module- Parameters:
- val- - if shared state enabled for the module.
 
 - 
setForceCallbacksReadpublic void setForceCallbacksRead(boolean val) Sets flag to force read call backs in auth chain process.- Parameters:
- val- - value to force reading call backs
 
 - 
isUseFirstPassEnabledpublic boolean isUseFirstPassEnabled() This method returns use first pass enabled or not- Returns:
- return true if use first pass is enabled for the module
 
 - 
getAMIdentityRepositorypublic AMIdentityRepository getAMIdentityRepository(String orgDN) ReturnsAMIdentityRepostioryhandle for an organization.- Parameters:
- orgDN- the organization name.
- Returns:
- AMIdentityRepostioryobject
 
 - 
createIdentitypublic void createIdentity(String userName, Map userAttributes, Set userRoles) throws IdRepoException, SSOException CreatesAMIdentityin the repository.- Parameters:
- userName- name of user to be created.
- userAttributes- Map of default attributes.
- userRoles- Set of default roles.
- Throws:
- IdRepoException
- SSOException
 
 - 
getFailCountpublic int getFailCount(AMIdentity amIdUser) throws AuthenticationException Get the number of failed login attempts for a user when account locking is enabled.- Returns:
- number of failed attempts, -1 id account locking is not enabled.
- Throws:
- AuthenticationException- if the user name passed in is not valid or null, or for any other error condition.
 
 - 
getMaximumFailCountpublic int getMaximumFailCount() throws AuthenticationExceptionGet the maximum number failed login attempts permitted for a user before when their account is locked out.- Returns:
- the maximum number of failed attempts
- Throws:
- AuthenticationException
 
 - 
incrementFailCountpublic void incrementFailCount(String userName) throws AuthenticationException Increments the fail count for the given user.- Throws:
- AuthenticationException- if the user name passed in is not valid or null, or for any other error condition.
 
 - 
isAccountLockedpublic boolean isAccountLocked(String userName) throws AuthenticationException Returns true if the named account is locked out, false otherwise.- Throws:
- AuthenticationException- if the user name passed in is not valid or null, or for any other error condition.
 
 - 
isSessionQuotaReachedpublic boolean isSessionQuotaReached(String userName) Returns true if the user identified by the supplied username has reached their session quota.
 NBThe existing session count is exclusive of any session created as part of the running authentication process- Parameters:
- userName- the username of the user who's session quota will be checked
- Returns:
- true if the user session quota is reached, false otherwise
 
 - 
getUserSessionspublic Set<SSOToken> getUserSessions(String userName) Returns the set of SSOTokens for a specified user- Parameters:
- userName- The username to be used to query the sessions
- Returns:
- The set of SSOTokens for the user's current sessions, returns null on error
 
 - 
getUserAliasListprotected Set<String> getUserAliasList() throws AuthLoginException Provides the "Alias Search Attribute Name" list from the Authentication Service for the realm. If these attributes are not configured it falls back to the User Naming Attribute for the realm- Returns:
- a set containing the attribute names configured
- Throws:
- AuthLoginException
 
 - 
getAuthenticatedPrincipalsprotected Set<String> getAuthenticatedPrincipals() Returns the principals authenticated in the current authentication process or an empty set if login state is unavailable or no authenticated principals are present.- Returns:
- a set of authenticated principals.
 
 - 
getAuditEntryDetailprotected AuthenticationAuditEntry getAuditEntryDetail() Supply the additional detail to be logged with this module's completion event. Subclasses can override this method to add more specific detail.- Returns:
- The audit entry detail.
 
 
- 
 
-