public class HybridAuthProvider extends Object implements AuthProvider
MappedAuthProvider. The Hybrid variant of the provider iterates
over providers, operating on the first applicable instance. The Mapped variant, however, maps each user to exactly
one provider.
To enable this provider, set the provider.auth.className system property to
org.jivesoftware.openfire.auth.HybridAuthProvider.
The primary, secondary, and tertiary providers are configured be setting system properties similar to
the following:
The full list of properties:
| Constructor and Description |
|---|
HybridAuthProvider() |
| Modifier and Type | Method and Description |
|---|---|
void |
authenticate(String username,
String password)
Returns if the username and password are valid; otherwise this
method throws an UnauthorizedException.
|
int |
getIterations(String username) |
String |
getPassword(String username)
Returns the user's password.
|
String |
getSalt(String username) |
String |
getServerKey(String username) |
String |
getStoredKey(String username) |
boolean |
isScramSupported() |
void |
setPassword(String username,
String password)
Sets the users's password.
|
boolean |
supportsPasswordRetrieval()
Returns true if this UserProvider is able to retrieve user passwords from
the backend user store.
|
public void authenticate(String username, String password) throws UnauthorizedException, ConnectionException, InternalUnauthenticatedException
AuthProviderauthenticate in interface AuthProviderusername - the username or full JID.password - the passwordUnauthorizedException - if the username and password do
not match any existing user.ConnectionException - it there is a problem connecting to user and group systemInternalUnauthenticatedException - if there is a problem authentication Openfire itself into the user and group systempublic String getPassword(String username) throws UserNotFoundException, UnsupportedOperationException
AuthProvidergetPassword in interface AuthProviderusername - the username of the user.UserNotFoundException - if the given user's password could not be loaded.UnsupportedOperationException - if the provider does not
support the operation (this is an optional operation).public void setPassword(String username, String password) throws UserNotFoundException, UnsupportedOperationException
AuthProvidersetPassword in interface AuthProviderusername - the username of the user.password - the new plaintext password for the user.UserNotFoundException - if the given user could not be loaded.UnsupportedOperationException - if the provider does not
support the operation (this is an optional operation).public boolean supportsPasswordRetrieval()
AuthProviderAuthProvider.getPassword(String)
will throw an UnsupportedOperationException if invoked.supportsPasswordRetrieval in interface AuthProviderpublic boolean isScramSupported()
isScramSupported in interface AuthProviderpublic String getSalt(String username) throws UnsupportedOperationException, UserNotFoundException
getSalt in interface AuthProviderUnsupportedOperationExceptionUserNotFoundExceptionpublic int getIterations(String username) throws UnsupportedOperationException, UserNotFoundException
getIterations in interface AuthProviderUnsupportedOperationExceptionUserNotFoundExceptionpublic String getServerKey(String username) throws UnsupportedOperationException, UserNotFoundException
getServerKey in interface AuthProviderUnsupportedOperationExceptionUserNotFoundExceptionpublic String getStoredKey(String username) throws UnsupportedOperationException, UserNotFoundException
getStoredKey in interface AuthProviderUnsupportedOperationExceptionUserNotFoundExceptionCopyright © 2003-2008 Jive Software.