Package org.h2.security.auth
Class DefaultAuthenticator
java.lang.Object
org.h2.security.auth.DefaultAuthenticator
- All Implemented Interfaces:
Authenticator
Default authenticator implementation.
When client connectionInfo contains property AUTHREALM={realName} credentials
(typically user id and password) are validated by
CredentialsValidator configured for that realm.
When client connectionInfo doesn't contains AUTHREALM property credentials are validated internally on the database
Rights assignment can be managed through UserToRolesMapper
Default configuration has a realm H2 that validate credentials through JAAS api (appName=h2). To customize configuration set h2.authConfigFile system property to refer a valid h2auth.xml config file
-
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionCreate the Authenticator with default configurationsDefaultAuthenticator(boolean skipDefaultInitialization) Create authenticator and optionally skip the default configuration. -
Method Summary
Modifier and TypeMethodDescriptionvoidaddRealm(String name, CredentialsValidator credentialsValidator) Add an authentication realm.final Userauthenticate(AuthenticationInfo authenticationInfo, Database database) Perform user authentication.voidconfigureFromUrl(URL configUrl) Configure the authenticator from a configuration fileprotected static final DefaultAuthenticatorUserToRoleMappers assign roles to authenticated usersvoidInitializes the authenticator.booleanIf set create external users in the database if not present.booleanWhen set create roles not found in the database.booleanIf set save users externals defined during the authentication.voidsetAllowUserRegistration(boolean allowUserRegistration) If set totruecreates external users in the database if not present.voidsetCreateMissingRoles(boolean createMissingRoles) Sets the flag that define behavior in case external roles not found in the database.voidsetPersistUsers(boolean persistUsers) If set totruesaves users externals defined during the authentication.voidsetUserToRolesMappers(UserToRolesMapper... userToRolesMappers)
-
Field Details
-
DEFAULT_REALMNAME
- See Also:
-
-
Constructor Details
-
DefaultAuthenticator
public DefaultAuthenticator()Create the Authenticator with default configurations -
DefaultAuthenticator
public DefaultAuthenticator(boolean skipDefaultInitialization) Create authenticator and optionally skip the default configuration. This option is useful when the authenticator is configured at code level- Parameters:
skipDefaultInitialization- if true default initialization is skipped
-
-
Method Details
-
getInstance
-
isPersistUsers
public boolean isPersistUsers()If set save users externals defined during the authentication.- Returns:
trueif user will be persisted, otherwise returnsfalse
-
setPersistUsers
public void setPersistUsers(boolean persistUsers) If set totruesaves users externals defined during the authentication.- Parameters:
persistUsers-trueif user will be persisted, otherwisefalse.
-
isAllowUserRegistration
public boolean isAllowUserRegistration()If set create external users in the database if not present.- Returns:
trueif creation external user is allowed, otherwise returnsfalse
-
setAllowUserRegistration
public void setAllowUserRegistration(boolean allowUserRegistration) If set totruecreates external users in the database if not present.- Parameters:
allowUserRegistration-trueif creation external user is allowed, otherwise returnsfalse
-
isCreateMissingRoles
public boolean isCreateMissingRoles()When set create roles not found in the database. If not set roles not found in the database are silently skipped.- Returns:
trueif not found roles will be created,falseroles are silently skipped.
-
setCreateMissingRoles
public void setCreateMissingRoles(boolean createMissingRoles) Sets the flag that define behavior in case external roles not found in the database.- Parameters:
createMissingRoles- when istruenot found roles are created, when isfalseroles are silently skipped.
-
addRealm
Add an authentication realm. Realms are case insensitive- Parameters:
name- realm namecredentialsValidator- credentials validator for realm
-
getUserToRolesMappers
UserToRoleMappers assign roles to authenticated users- Returns:
- current UserToRoleMappers active
-
setUserToRolesMappers
-
init
Initializes the authenticator. this method is skipped if skipDefaultInitialization is set Order of initialization is- Check h2.authConfigFile system property.
- Use the default configuration hard coded
- Specified by:
initin interfaceAuthenticator- Parameters:
database- where authenticator is initialized- Throws:
AuthConfigException
-
configureFromUrl
public void configureFromUrl(URL configUrl) throws AuthenticationException, SAXException, IOException, ParserConfigurationException Configure the authenticator from a configuration file- Parameters:
configUrl- URL of configuration file- Throws:
AuthenticationException- on failureSAXException- on failureIOException- on failureParserConfigurationException- on failure
-
authenticate
public final User authenticate(AuthenticationInfo authenticationInfo, Database database) throws AuthenticationException Description copied from interface:AuthenticatorPerform user authentication.- Specified by:
authenticatein interfaceAuthenticator- Parameters:
authenticationInfo- authentication info.database- target database instance.- Returns:
- valid database user or null if user doesn't exists in the database
- Throws:
AuthenticationException- on failure
-