public class PropertyBasedUserProviderMapper extends Object implements UserProviderMapper
UserProviderMapper
that can be used to draw some users from another source than the other users.
This implementation uses properties to define sets of usernames and a corresponding provider. When a user is not in
any set, a fallback provider is used.
Each set of usernames is defined by two properties. Use the following property to define the classname of an
UserProvider
to be used for this set: propertyBasedUserMapper.set.SET_NAME.provider.className
Use the following property to identify a set of usernames: propertyBasedUserMapper.set.SET_NAME.members
. The
value for this property must be the name of another property, which is a listing of usernames (such a property is
likely re-used in a corresponding PropertyBasedAuthProviderMapper
configuration).
There is no upper bound on the amount of sets that can be configured.
Users that are not in any set will use the fallback provider. This provider is defined by its class name in the
property propertyBasedUserMapper.fallbackProvider.className
.
The following example defines two sets. Set "A" serves users john, jane and jack, and uses a DefaultUserProvider.
Set "B" serves users dave and doris, and uses A JDBCUserProvider. All other users are served by the fallback provider
that is a NativeUserProvider.
members.set.A = List( "john", "jane", "jack" )
members.set.B = List( "dave", "doris" )
propertyBasedUserMapper.set.A.provider.className = org.jivesoftware.openfire.user.DefaultUserProvider
propertyBasedUserMapper.set.A.members.propertyName = members.set.A
propertyBasedUserMapper.set.B.provider.className = org.jivesoftware.openfire.user.JDBCUserProvider
propertyBasedUserMapper.set.B.members.propertyName = members.set.B
propertyBasedUserMapper.fallbackProvider.className = org.jivesoftware.openfire.auth.NativeUserProvider
Modifier and Type | Field and Description |
---|---|
protected UserProvider |
fallbackProvider |
protected Map<String,UserProvider> |
providersByPrefix |
Constructor and Description |
---|
PropertyBasedUserProviderMapper() |
Modifier and Type | Method and Description |
---|---|
UserProvider |
getUserProvider(String username)
Finds a suitable UserProvider for the user.
|
Set<UserProvider> |
getUserProviders()
Returns all providers that are used by this instance.
|
protected final Map<String,UserProvider> providersByPrefix
protected UserProvider fallbackProvider
public UserProvider getUserProvider(String username)
UserProviderMapper
getUserProvider
in interface UserProviderMapper
username
- A user identifier (cannot be null or empty).public Set<UserProvider> getUserProviders()
UserProviderMapper
getUserProviders
in interface UserProviderMapper
Copyright © 2003–2019 Ignite Realtime. All rights reserved.