Class FakeUserManagerImpl
- java.lang.Object
-
- org.nuxeo.ecm.platform.usermanager.FakeUserManagerImpl
-
- All Implemented Interfaces:
Serializable
,UserManager
,Authenticator
,EventListener
public class FakeUserManagerImpl extends Object implements UserManager
- Author:
- Florent Guillaume
- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.nuxeo.ecm.platform.usermanager.UserManager
UserManager.MatchType
-
-
Constructor Summary
Constructors Constructor Description FakeUserManagerImpl()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Boolean
areGroupsReadOnly()
Returns true is users referential is read only (ie : LDAP) -> can not add users -> can not delete users.Boolean
areUsersReadOnly()
Returns true is groups referential is read only (ie : LDAP) -> can not add groups -> can not delete groups.Principal
authenticate(String name, String password)
Get a principal object for the given username if the username / password pair is valid, otherwise returns null.boolean
checkUsernamePassword(String username, String password)
Check the password for the given username.DocumentModel
createGroup(DocumentModel groupModel)
Creates a group from given modelDocumentModel
createUser(DocumentModel userModel)
Creates user from given model.void
deleteGroup(String groupId)
Deletes group with given id.void
deleteGroup(DocumentModel groupModel)
Deletes group represented by given model.void
deleteUser(String userId)
Deletes user with given id.void
deleteUser(DocumentModel userModel)
Deletes user represented by given model.List<String>
getAdministratorsGroups()
Returns the list of administrators groups.List<String>
getAncestorGroups(String groupId)
Returns the ancestor groups of the group with the given id.String
getAnonymousUserId()
Gets the anonymous user id.DocumentModel
getBareGroupModel()
Returns a bare group model.DocumentModel
getBareUserModel()
Returns a bare user model.String
getDefaultGroup()
List<String>
getDescendantGroups(String groupId)
Returns the descendant groups of the group with the given id.String
getDigestAuthDirectory()
Gets the Digest Auth directory.String
getDigestAuthRealm()
Gets the Digest Auth realm.NuxeoGroup
getGroup(String groupName)
Returns the nuxeo group with given name or null if it does not exist.GroupConfig
getGroupConfig()
Returns the contributedGroupConfig
.String
getGroupDirectoryName()
Gets the group directory name.String
getGroupIdField()
Returns the group directory id field.List<String>
getGroupIds()
Returns the list of all groups ids.String
getGroupLabelField()
Returns the group label field.String
getGroupListingMode()
String
getGroupMembersField()
Gets the group members field.DocumentModel
getGroupModel(String groupName)
Return the group document model with this id or null if group does not exist.String
getGroupParentGroupsField()
Gets the group parent-groups field.String
getGroupSchemaName()
Returns the group directory schema name.Set<String>
getGroupSearchFields()
Gets the group search fields.List<String>
getGroupsInGroup(String parentId)
Returns the list of groups that belong to this group.String
getGroupSubGroupsField()
Gets the group sub-groups field.NuxeoPrincipal
getPrincipal(String username, boolean fetchReferences)
Retrieves the principal with the given username or null if it does not exist.List<String>
getTopLevelGroups()
Returns the list of groups that are not members of other groups.String
getUserDirectoryName()
Gets the user directory name.String
getUserEmailField()
Gets the user email field.String
getUserIdField()
Returns the user directory id field.List<String>
getUserIds()
Returns the list of all user ids.String
getUserListingMode()
DocumentModel
getUserModel(String userName)
Returns the document model representing user with given id or null if it does not exist.Pattern
getUserPasswordPattern()
String
getUserSchemaName()
Returns the user directory schema name.Set<String>
getUserSearchFields()
Gets the user search fields, the fields to use when a principal search is done.String[]
getUsersForPermission(String perm, ACP acp)
For an ACP, get the list of user that has a permission.List<String>
getUsersInGroup(String groupId)
Returns the list of users that belong to this group.List<String>
getUsersInGroupAndSubGroups(String groupId)
Get users from a group and its subgroups.String
getUserSortField()
void
handleEvent(Event event)
An event was received.void
notifyGroupChanged(String groupName, String eventId, List<String> ancestorGroupNames)
Notifies that the given group has changed with the given event: At the runtime level so that the JaasCacheFlusher listener can make sure the principal cache is reset. At the core level, passing thegroupName
as the"id"
property of the fired event.void
notifyUserChanged(String userName, String eventId)
Notifies that the given user has changed with the given event: At the runtime level so that the JaasCacheFlusher listener can make sure the principal cache is reset. At the core level, passing theuserName
as the"id"
property of the fired event.DocumentModelList
searchGroups(String pattern)
Search matching groups through their defined search fieldsDocumentModelList
searchGroups(Map<String,Serializable> filter, Set<String> fulltext)
Returns groups matching given criteria.DocumentModelList
searchGroups(QueryBuilder queryBuilder)
Returns groups matching the given query.List<NuxeoPrincipal>
searchPrincipals(String pattern)
DocumentModelList
searchUsers(String pattern)
Returns users matching given patternDocumentModelList
searchUsers(Map<String,Serializable> filter, Set<String> fulltext)
Returns users matching given criteria.DocumentModelList
searchUsers(QueryBuilder queryBuilder)
Returns users matching the given query.void
setAnonymousUser(VirtualUser anonymousUser)
void
setConfiguration(UserManagerDescriptor descriptor)
Sets the given configuration on the service.void
setDefaultGroup(String defaultGroup)
void
setGroupDirectoryName(String groupDirectoryName)
void
setGroupListingMode(String groupListingMode)
void
setGroupMembersField(String groupMembersField)
void
setGroupParentGroupsField(String groupParentGroupsField)
void
setGroupSearchFields(Map<String,UserManager.MatchType> groupSearchFields)
void
setGroupSortField(String sortField)
void
setGroupSubGroupsField(String groupSubGroupsField)
void
setUserDirectoryName(String userDirectoryName)
void
setUserEmailField(String userEmailField)
void
setUserListingMode(String userListingMode)
void
setUserPasswordPattern(Pattern userPasswordPattern)
void
setUserSearchFields(Map<String,UserManager.MatchType> userSearchFields)
void
setUserSearchFields(Set<String> userSearchFields)
void
setUserSortField(String sortField)
void
setVirtualUsers(Map<String,VirtualUserDescriptor> virtualUsers)
void
updateGroup(DocumentModel groupModel)
Updates group represented by given model.void
updateUser(DocumentModel userModel)
Updates user represented by given model.boolean
validatePassword(String password)
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.nuxeo.ecm.platform.usermanager.UserManager
getPrincipal, notifyGroupChanged
-
-
-
-
Method Detail
-
getUserListingMode
public String getUserListingMode()
- Specified by:
getUserListingMode
in interfaceUserManager
-
setUserListingMode
public void setUserListingMode(String userListingMode)
-
getGroupListingMode
public String getGroupListingMode()
- Specified by:
getGroupListingMode
in interfaceUserManager
-
setGroupListingMode
public void setGroupListingMode(String groupListingMode)
-
getDefaultGroup
public String getDefaultGroup()
- Specified by:
getDefaultGroup
in interfaceUserManager
-
setDefaultGroup
public void setDefaultGroup(String defaultGroup)
-
getUserSortField
public String getUserSortField()
- Specified by:
getUserSortField
in interfaceUserManager
-
setUserSortField
public void setUserSortField(String sortField)
-
setGroupSortField
public void setGroupSortField(String sortField)
-
setUserDirectoryName
public void setUserDirectoryName(String userDirectoryName)
-
getUserDirectoryName
public String getUserDirectoryName()
Description copied from interface:UserManager
Gets the user directory name.- Specified by:
getUserDirectoryName
in interfaceUserManager
- Returns:
- the user directory name.
-
setUserEmailField
public void setUserEmailField(String userEmailField)
-
getUserEmailField
public String getUserEmailField()
Description copied from interface:UserManager
Gets the user email field.- Specified by:
getUserEmailField
in interfaceUserManager
- Returns:
- the user email field.
-
setUserSearchFields
public void setUserSearchFields(Map<String,UserManager.MatchType> userSearchFields)
-
getUserSearchFields
public Set<String> getUserSearchFields()
Description copied from interface:UserManager
Gets the user search fields, the fields to use when a principal search is done.- Specified by:
getUserSearchFields
in interfaceUserManager
- Returns:
- the search fields.
-
setGroupSearchFields
public void setGroupSearchFields(Map<String,UserManager.MatchType> groupSearchFields)
-
getGroupSearchFields
public Set<String> getGroupSearchFields()
Description copied from interface:UserManager
Gets the group search fields.- Specified by:
getGroupSearchFields
in interfaceUserManager
-
setGroupDirectoryName
public void setGroupDirectoryName(String groupDirectoryName)
-
getGroupDirectoryName
public String getGroupDirectoryName()
Description copied from interface:UserManager
Gets the group directory name.- Specified by:
getGroupDirectoryName
in interfaceUserManager
- Returns:
- the group directory name.
-
setGroupMembersField
public void setGroupMembersField(String groupMembersField)
-
getGroupMembersField
public String getGroupMembersField()
Description copied from interface:UserManager
Gets the group members field.- Specified by:
getGroupMembersField
in interfaceUserManager
- Returns:
- the group members field.
-
setGroupSubGroupsField
public void setGroupSubGroupsField(String groupSubGroupsField)
-
getGroupSubGroupsField
public String getGroupSubGroupsField()
Description copied from interface:UserManager
Gets the group sub-groups field.- Specified by:
getGroupSubGroupsField
in interfaceUserManager
- Returns:
- the sub-groups field.
-
setGroupParentGroupsField
public void setGroupParentGroupsField(String groupParentGroupsField)
-
getGroupParentGroupsField
public String getGroupParentGroupsField()
Description copied from interface:UserManager
Gets the group parent-groups field.- Specified by:
getGroupParentGroupsField
in interfaceUserManager
- Returns:
- the parent-groups field.
-
areGroupsReadOnly
public Boolean areGroupsReadOnly()
Description copied from interface:UserManager
Returns true is users referential is read only (ie : LDAP) -> can not add users -> can not delete users.- Specified by:
areGroupsReadOnly
in interfaceUserManager
-
areUsersReadOnly
public Boolean areUsersReadOnly()
Description copied from interface:UserManager
Returns true is groups referential is read only (ie : LDAP) -> can not add groups -> can not delete groups.- Specified by:
areUsersReadOnly
in interfaceUserManager
-
checkUsernamePassword
public boolean checkUsernamePassword(String username, String password)
Description copied from interface:Authenticator
Check the password for the given username. Returns true if the username / password pair match, false otherwise.- Specified by:
checkUsernamePassword
in interfaceAuthenticator
- Specified by:
checkUsernamePassword
in interfaceUserManager
- Parameters:
username
- the usernamepassword
- the password to check- Returns:
- true is valid, false otherwise
-
validatePassword
public boolean validatePassword(String password)
- Specified by:
validatePassword
in interfaceUserManager
-
getGroupsInGroup
public List<String> getGroupsInGroup(String parentId)
Description copied from interface:UserManager
Returns the list of groups that belong to this group.- Specified by:
getGroupsInGroup
in interfaceUserManager
- Parameters:
parentId
- the name of the parent group.
-
getPrincipal
public NuxeoPrincipal getPrincipal(String username, boolean fetchReferences)
Description copied from interface:UserManager
Retrieves the principal with the given username or null if it does not exist.Can build principals for anonymous and virtual users as well as for users defined in the users directory.
- Specified by:
getPrincipal
in interfaceUserManager
- Parameters:
username
- is the name of the entry in the user directoryfetchReferences
- controls if the references (groups) of the user will be fetched
-
getTopLevelGroups
public List<String> getTopLevelGroups()
Description copied from interface:UserManager
Returns the list of groups that are not members of other groups.- Specified by:
getTopLevelGroups
in interfaceUserManager
-
getUsersInGroup
public List<String> getUsersInGroup(String groupId)
Description copied from interface:UserManager
Returns the list of users that belong to this group.- Specified by:
getUsersInGroup
in interfaceUserManager
- Parameters:
groupId
- ID of the group
-
getUsersInGroupAndSubGroups
public List<String> getUsersInGroupAndSubGroups(String groupId)
Description copied from interface:UserManager
Get users from a group and its subgroups.- Specified by:
getUsersInGroupAndSubGroups
in interfaceUserManager
- Parameters:
groupId
- ID of the group
-
searchGroups
public DocumentModelList searchGroups(String pattern)
Description copied from interface:UserManager
Search matching groups through their defined search fields- Specified by:
searchGroups
in interfaceUserManager
-
searchPrincipals
public List<NuxeoPrincipal> searchPrincipals(String pattern)
- Specified by:
searchPrincipals
in interfaceUserManager
-
getUserPasswordPattern
public Pattern getUserPasswordPattern()
- Specified by:
getUserPasswordPattern
in interfaceUserManager
-
setUserPasswordPattern
public void setUserPasswordPattern(Pattern userPasswordPattern)
-
setAnonymousUser
public void setAnonymousUser(VirtualUser anonymousUser)
-
setVirtualUsers
public void setVirtualUsers(Map<String,VirtualUserDescriptor> virtualUsers)
-
getAnonymousUserId
public String getAnonymousUserId()
Description copied from interface:UserManager
Gets the anonymous user id.- Specified by:
getAnonymousUserId
in interfaceUserManager
- Returns:
- the anonymous user id, or the default one if none is defined.
-
getDigestAuthDirectory
public String getDigestAuthDirectory()
Description copied from interface:UserManager
Gets the Digest Auth directory.- Specified by:
getDigestAuthDirectory
in interfaceUserManager
-
getDigestAuthRealm
public String getDigestAuthRealm()
Description copied from interface:UserManager
Gets the Digest Auth realm.- Specified by:
getDigestAuthRealm
in interfaceUserManager
-
setConfiguration
public void setConfiguration(UserManagerDescriptor descriptor)
Description copied from interface:UserManager
Sets the given configuration on the service.- Specified by:
setConfiguration
in interfaceUserManager
- Parameters:
descriptor
- the descriptor as parsed from xml, merged from the previous one if it exists.
-
getBareUserModel
public DocumentModel getBareUserModel()
Description copied from interface:UserManager
Returns a bare user model.Can be used for user creation/search screens.
- Specified by:
getBareUserModel
in interfaceUserManager
-
createGroup
public DocumentModel createGroup(DocumentModel groupModel)
Description copied from interface:UserManager
Creates a group from given model- Specified by:
createGroup
in interfaceUserManager
- Returns:
- the created group model
-
createUser
public DocumentModel createUser(DocumentModel userModel)
Description copied from interface:UserManager
Creates user from given model.- Specified by:
createUser
in interfaceUserManager
-
deleteGroup
public void deleteGroup(DocumentModel groupModel)
Description copied from interface:UserManager
Deletes group represented by given model.- Specified by:
deleteGroup
in interfaceUserManager
-
deleteGroup
public void deleteGroup(String groupId)
Description copied from interface:UserManager
Deletes group with given id.- Specified by:
deleteGroup
in interfaceUserManager
-
deleteUser
public void deleteUser(DocumentModel userModel)
Description copied from interface:UserManager
Deletes user represented by given model.- Specified by:
deleteUser
in interfaceUserManager
-
deleteUser
public void deleteUser(String userId)
Description copied from interface:UserManager
Deletes user with given id.- Specified by:
deleteUser
in interfaceUserManager
-
getBareGroupModel
public DocumentModel getBareGroupModel()
Description copied from interface:UserManager
Returns a bare group model.Can be used for group creation/search screens.
- Specified by:
getBareGroupModel
in interfaceUserManager
-
getGroup
public NuxeoGroup getGroup(String groupName)
Description copied from interface:UserManager
Returns the nuxeo group with given name or null if it does not exist.- Specified by:
getGroup
in interfaceUserManager
-
getGroupIds
public List<String> getGroupIds()
Description copied from interface:UserManager
Returns the list of all groups ids.- Specified by:
getGroupIds
in interfaceUserManager
-
getUserIds
public List<String> getUserIds()
Description copied from interface:UserManager
Returns the list of all user ids.- Specified by:
getUserIds
in interfaceUserManager
-
searchGroups
public DocumentModelList searchGroups(Map<String,Serializable> filter, Set<String> fulltext)
Description copied from interface:UserManager
Returns groups matching given criteria.- Specified by:
searchGroups
in interfaceUserManager
- Parameters:
filter
- filter with field names as keysfulltext
- field names used for fulltext match
-
searchGroups
public DocumentModelList searchGroups(QueryBuilder queryBuilder)
Description copied from interface:UserManager
Returns groups matching the given query.- Specified by:
searchGroups
in interfaceUserManager
- Parameters:
queryBuilder
- the query to use, including limit, offset, ordering and countTotal
-
searchUsers
public DocumentModelList searchUsers(Map<String,Serializable> filter, Set<String> fulltext)
Description copied from interface:UserManager
Returns users matching given criteria.- Specified by:
searchUsers
in interfaceUserManager
- Parameters:
filter
- filter with field names as keysfulltext
- field names used for fulltext match
-
searchUsers
public DocumentModelList searchUsers(String pattern)
Description copied from interface:UserManager
Returns users matching given patternPattern is used to fill a filter and fulltext map according to users search fields configuration. Search is performed on each of these fields (OR).
- Specified by:
searchUsers
in interfaceUserManager
-
searchUsers
public DocumentModelList searchUsers(QueryBuilder queryBuilder)
Description copied from interface:UserManager
Returns users matching the given query.- Specified by:
searchUsers
in interfaceUserManager
- Parameters:
queryBuilder
- the query to use, including limit, offset, ordering and countTotal
-
updateGroup
public void updateGroup(DocumentModel groupModel)
Description copied from interface:UserManager
Updates group represented by given model.- Specified by:
updateGroup
in interfaceUserManager
-
updateUser
public void updateUser(DocumentModel userModel)
Description copied from interface:UserManager
Updates user represented by given model.- Specified by:
updateUser
in interfaceUserManager
-
getGroupModel
public DocumentModel getGroupModel(String groupName)
Description copied from interface:UserManager
Return the group document model with this id or null if group does not exist.- Specified by:
getGroupModel
in interfaceUserManager
- Parameters:
groupName
- the group identifier
-
getUserModel
public DocumentModel getUserModel(String userName)
Description copied from interface:UserManager
Returns the document model representing user with given id or null if it does not exist.- Specified by:
getUserModel
in interfaceUserManager
-
getGroupIdField
public String getGroupIdField()
Description copied from interface:UserManager
Returns the group directory id field.- Specified by:
getGroupIdField
in interfaceUserManager
-
getGroupLabelField
public String getGroupLabelField()
Description copied from interface:UserManager
Returns the group label field.- Specified by:
getGroupLabelField
in interfaceUserManager
-
getGroupSchemaName
public String getGroupSchemaName()
Description copied from interface:UserManager
Returns the group directory schema name.- Specified by:
getGroupSchemaName
in interfaceUserManager
-
getUserIdField
public String getUserIdField()
Description copied from interface:UserManager
Returns the user directory id field.- Specified by:
getUserIdField
in interfaceUserManager
-
getUserSchemaName
public String getUserSchemaName()
Description copied from interface:UserManager
Returns the user directory schema name.- Specified by:
getUserSchemaName
in interfaceUserManager
-
getAdministratorsGroups
public List<String> getAdministratorsGroups()
Description copied from interface:UserManager
Returns the list of administrators groups.- Specified by:
getAdministratorsGroups
in interfaceUserManager
-
getUsersForPermission
public String[] getUsersForPermission(String perm, ACP acp)
Description copied from interface:UserManager
For an ACP, get the list of user that has a permission. This method should be use with care as it can cause performance issues while getting the list of users.- Specified by:
getUsersForPermission
in interfaceUserManager
- Parameters:
perm
- the permissionacp
- The access control policy of the document- Returns:
- the list of user ids
-
authenticate
public Principal authenticate(String name, String password)
Description copied from interface:Authenticator
Get a principal object for the given username if the username / password pair is valid, otherwise returns null.This method is doing the authentication of the given username / password pair and returns the corresponding principal object if authentication succeeded otherwise returns null.
- Specified by:
authenticate
in interfaceAuthenticator
- Returns:
- the authenticated principal if authentication succeded otherwise null
-
handleEvent
public void handleEvent(Event event)
Description copied from interface:EventListener
An event was received.- Specified by:
handleEvent
in interfaceEventListener
-
getAncestorGroups
public List<String> getAncestorGroups(String groupId)
Description copied from interface:UserManager
Returns the ancestor groups of the group with the given id.- Specified by:
getAncestorGroups
in interfaceUserManager
-
getDescendantGroups
public List<String> getDescendantGroups(String groupId)
Description copied from interface:UserManager
Returns the descendant groups of the group with the given id.- Specified by:
getDescendantGroups
in interfaceUserManager
-
getGroupConfig
public GroupConfig getGroupConfig()
Description copied from interface:UserManager
Returns the contributedGroupConfig
.- Specified by:
getGroupConfig
in interfaceUserManager
-
notifyUserChanged
public void notifyUserChanged(String userName, String eventId)
Description copied from interface:UserManager
Notifies that the given user has changed with the given event:- At the runtime level so that the JaasCacheFlusher listener can make sure the principal cache is reset.
- At the core level, passing the
userName
as the"id"
property of the fired event.
- Specified by:
notifyUserChanged
in interfaceUserManager
-
notifyGroupChanged
public void notifyGroupChanged(String groupName, String eventId, List<String> ancestorGroupNames)
Description copied from interface:UserManager
Notifies that the given group has changed with the given event:- At the runtime level so that the JaasCacheFlusher listener can make sure the principal cache is reset.
- At the core level, passing the
groupName
as the"id"
property of the fired event.
The
ancestorGroupNames
list must contain the ancestor groups of the given group. It can be computed by callingUserManager.getAncestorGroups(String)
. It will be passed as the"ancestorGroups"
property of the fired core event.- Specified by:
notifyGroupChanged
in interfaceUserManager
-
-