Interface PersonService
- All Known Implementing Classes:
PersonServiceImpl
@AlfrescoPublicApi
public interface PersonService
This service encapsulates the management of people and groups.
People and groups may be managed entirely in the repository or entirely in some other implementation such as LDAP or via NTLM. Some properties may in the repository and some in another store. Individual properties may or may not be mutable.
- Author:
- Andy Hind
-
Nested Class Summary
Nested ClassesModifier and TypeInterfaceDescriptionstatic classData pojo to carry common person information -
Method Summary
Modifier and TypeMethodDescriptionintCounts the number of persons registered with the system.booleanDoes this service create people on demand if they are missing.createPerson(Map<QName, Serializable> properties) Create a new person with the given properties.createPerson(Map<QName, Serializable> properties, Set<String> zones) Create a new person with the given properties, recording them against the given zone name (usually identifying an external user registry from which the details were obtained).voiddeletePerson(String userName) Delete the person identified by the given user name.voiddeletePerson(NodeRef personRef) Delete the person identified by the given ref.voiddeletePerson(NodeRef personRef, boolean deleteAuthentication) Delete the person identified by the given ref, and optionally delete the associated authentication, if one.Deprecated.Get the list of properties that are mutable.org.alfresco.query.PagingResults<PersonService.PersonInfo>getPeople(String pattern, List<QName> filterProps, List<Pair<QName, Boolean>> sortProps, org.alfresco.query.PagingRequest pagingRequest) Get paged list of people optionally filtered and/or sorted Note: the pattern is applied to filter props (0 to 3) as startsWithIgnoreCase, which are OR'ed together, for example: cm:userName or cm:firstName or cm:lastNameorg.alfresco.query.PagingResults<PersonService.PersonInfo>getPeople(String pattern, List<QName> filterStringProps, Set<QName> inclusiveAspects, Set<QName> exclusiveAspects, boolean includeAdministraotrs, List<Pair<QName, Boolean>> sortProps, org.alfresco.query.PagingRequest pagingRequest) Get paged list of people optionally filtered and/or sortedorg.alfresco.query.PagingResults<PersonService.PersonInfo>getPeople(List<Pair<QName, String>> stringPropFilters, boolean filterIgnoreCase, List<Pair<QName, Boolean>> sortProps, org.alfresco.query.PagingRequest pagingRequest) Deprecated.see getPeople(String pattern, ListfilterProps, List<Pair<QName, Boolean>> sortProps, PagingRequest pagingRequest) Return the container that stores people.getPeopleFilteredByProperty(QName propertyKey, Serializable propertyValue, int count) Get people filtered by the given property name/value pair.Get a person by userName.Retrieve the person NodeRef for ausername, optionally creating the home folder if it does not exist and optionally creating the person if they don't exist AND the PersonService is configured to allow the creation of missing personssetCreateMissingPeople(boolean).Retrieve the person info for an existingperson NodeRefgetPersonOrNull(String userName) Get a person by userName.getUserIdentifier(String caseSensitiveUserName) Given the case sensitive user name find the approriate identifier from the person service.booleanAre user names case sensitive?booleanIs the specified user, enabledbooleanCan this service create, delete and update person information?voidnotifyPerson(String userName, String password) Notifies a user by email that their account has been created, and the details of it.booleanpersonExists(String userName) Check if a person exists.voidsetCreateMissingPeople(boolean createMissing) Set if missing people should be created.voidsetPersonProperties(String userName, Map<QName, Serializable> properties) Set the properties on a person - some of these may be persisted in different locations - the home folder is created if it doesn't existvoidsetPersonProperties(String userName, Map<QName, Serializable> properties, boolean autoCreateHomeFolder) Set the properties on a person - some of these may be persisted in different locations.
-
Method Details
-
getPerson
Get a person by userName. The person is store in the repository. The person may be created as a side effect of this call, depending on the setting ofto create missing people or not. The home folder will also be created as a side effect if it does not exist.- Parameters:
userName- - the userName key to find the person- Returns:
- Returns the person node, either existing or new
- Throws:
NoSuchPersonException- if the user doesn't exist and could not be created automatically- See Also:
-
getPersonOrNull
Get a person by userName. The person is store in the repository. No missing person objects will be created as a side effect of this call. If the person is missing from the repository null will be returned.- Parameters:
userName- - the userName key to find the person- Returns:
- Returns the existing person node, or null if does not exist.
- See Also:
-
getPerson
@Auditable(parameters={"userName","autoCreate"}) NodeRef getPerson(String userName, boolean autoCreateHomeFolderAndMissingPersonIfAllowed) Retrieve the person NodeRef for ausername, optionally creating the home folder if it does not exist and optionally creating the person if they don't exist AND the PersonService is configured to allow the creation of missing personssetCreateMissingPeople(boolean). If not allowed to create missing persons and the person does not exist aNoSuchPersonExceptionexception will be thrown.- Parameters:
userName- of the person NodeRef to retrieveautoCreateHomeFolderAndMissingPersonIfAllowed- If the person exits: should we create the home folder if it does not exist? If the person exists AND the creation of missing persons is allowed should we create both the person and home folder.- Returns:
- NodeRef of the person as specified by the username
- Throws:
NoSuchPersonException- if the person doesn't exist and can't be created
-
getPerson
@Auditable(parameters="personRef") PersonService.PersonInfo getPerson(NodeRef personRef) throws NoSuchPersonException Retrieve the person info for an existingperson NodeRef- Parameters:
personRef- NodeRef- Returns:
- PersonInfo (username, firstname, lastname)
- Throws:
NoSuchPersonException- if the person doesn't exist
-
personExists
Check if a person exists.- Parameters:
userName- the user name- Returns:
- Returns true if the user exists, otherwise false
-
createMissingPeople
Does this service create people on demand if they are missing. If this is true, a call to getPerson() will create a person if they are missing.- Returns:
- true if people are created on demand and false otherwise.
-
setCreateMissingPeople
Set if missing people should be created.- Parameters:
createMissing- set to true to create people- See Also:
-
getMutableProperties
Get the list of properties that are mutable. Some service may only allow a limited list of properties to be changed. This may be those persisted in the repository or those that can be changed in some other implementation such as LDAP.- Returns:
- A set of QNames that identify properties that can be changed
-
setPersonProperties
@Auditable(parameters={"userName","properties"}) void setPersonProperties(String userName, Map<QName, Serializable> properties) Set the properties on a person - some of these may be persisted in different locations - the home folder is created if it doesn't exist- Parameters:
userName- - the user for which the properties should be set.properties- - the map of properties to set (as the NodeService)
-
setPersonProperties
@Auditable(parameters={"userName","properties","autoCreate"}) void setPersonProperties(String userName, Map<QName, Serializable> properties, boolean autoCreateHomeFolder) Set the properties on a person - some of these may be persisted in different locations.- Parameters:
userName- - the user for which the properties should be set.properties- - the map of properties to set (as the NodeService)autoCreateHomeFolder- should we auto-create the home folder if it doesn't exist.
-
isMutable
Can this service create, delete and update person information?- Returns:
- true if this service allows mutation to people.
-
createPerson
Create a new person with the given properties. The userName is one of the properties. Users with duplicate userNames are not allowed.- Returns:
- NodeRef
-
createPerson
@Auditable(parameters={"properties","zones"}) NodeRef createPerson(Map<QName, Serializable> properties, Set<String> zones) Create a new person with the given properties, recording them against the given zone name (usually identifying an external user registry from which the details were obtained). The userName is one of the properties. Users with duplicate userNames are not allowed.- Parameters:
properties- the propertieszones- a set if zones including the identifier for the external user registry owning the person information, ornullor an empty set- Returns:
- the node ref
-
notifyPerson
Notifies a user by email that their account has been created, and the details of it. Normally called aftercreatePerson(Map)orcreatePerson(Map, Set)where email notifications are required.- Parameters:
userName- of the person to notifypassword- of the person to notify- Throws:
NoSuchPersonException- if the person doesn't exist
-
deletePerson
Delete the person identified by the given user name.- Parameters:
userName- String
-
deletePerson
Delete the person identified by the given ref.- Parameters:
personRef- NodeRef
-
deletePerson
@Auditable(parameters={"personRef","deleteAuthentication"}) void deletePerson(NodeRef personRef, boolean deleteAuthentication) Delete the person identified by the given ref, and optionally delete the associated authentication, if one.- Parameters:
personRef- NodeRefdeleteAuthentication- boolean
-
getAllPeople
Deprecated.Get all the people we know about.- Returns:
- a set of people in no specific order.
-
getPeople
@Auditable(parameters={"pattern","filterProps","sortProps","pagingRequest"}) org.alfresco.query.PagingResults<PersonService.PersonInfo> getPeople(String pattern, List<QName> filterProps, List<Pair<QName, Boolean>> sortProps, org.alfresco.query.PagingRequest pagingRequest) Get paged list of people optionally filtered and/or sorted Note: the pattern is applied to filter props (0 to 3) as startsWithIgnoreCase, which are OR'ed together, for example: cm:userName or cm:firstName or cm:lastName- Parameters:
pattern- pattern to apply to filter props - "startsWith" and "ignoreCase"filterProps- list of filter properties (these are OR'ed)sortProps- sort property, eg. cm:username ascendingpagingRequest- skip, max + optional query execution id
author janv- Since:
- 4.1.2
-
getPeople
@Auditable(parameters={"stringPropFilters","filterIgnoreCase","sortProps","pagingRequest"}) org.alfresco.query.PagingResults<PersonService.PersonInfo> getPeople(List<Pair<QName, String>> stringPropFilters, boolean filterIgnoreCase, List<Pair<QName, Boolean>> sortProps, org.alfresco.query.PagingRequest pagingRequest) Deprecated.see getPeople(String pattern, ListfilterProps, List<Pair<QName, Boolean>> sortProps, PagingRequest pagingRequest) Get paged list of people optionally filtered and/or sorted- Parameters:
stringPropFilters- list of filter properties (with "startsWith" values), eg. cm:username "al" might match "alex", "alice", ...filterIgnoreCase- true to ignore case when filtering, false to be case-sensitive when filteringsortProps- sort property, eg. cm:username ascendingpagingRequest- skip, max + optional query execution id
author janv- Since:
- 4.0
-
getPeople
@Auditable(parameters={"stringPropFilters","filterIgnoreCase","inclusiveAspect","exclusiveAspects","sortProps","pagingRequest"}) org.alfresco.query.PagingResults<PersonService.PersonInfo> getPeople(String pattern, List<QName> filterStringProps, Set<QName> inclusiveAspects, Set<QName> exclusiveAspects, boolean includeAdministraotrs, List<Pair<QName, Boolean>> sortProps, org.alfresco.query.PagingRequest pagingRequest) Get paged list of people optionally filtered and/or sorted- Parameters:
pattern- StringfilterStringProps- list of filter properties (with "startsWith" values), eg. cm:username "al" might match "alex", "alice", ...inclusiveAspects- if set, filter out any people that don't have one of these aspectsexclusiveAspects- if set, filter out any people that do have one of these aspectsincludeAdministraotrs- true to include administrators in the results.sortProps- sort property, eg. cm:username ascendingpagingRequest- skip, max + optional query execution id
-
getPeopleFilteredByProperty
@Auditable Set<NodeRef> getPeopleFilteredByProperty(QName propertyKey, Serializable propertyValue, int count) Get people filtered by the given property name/value pair. In order to get paging, usegetPeople(List, boolean, List, PagingRequest)- Parameters:
propertyKey- property key of property to filter people bypropertyValue- property value of property to filter people bycount- the number of results to retrieve, up to a maximum of 1000- Returns:
- people filtered by the given property name/value pair
- See Also:
-
getPeopleContainer
Return the container that stores people.- Returns:
- NodeRef
-
getUserNamesAreCaseSensitive
Are user names case sensitive?- Returns:
- boolean
-
getUserIdentifier
Given the case sensitive user name find the approriate identifier from the person service. If the system is case sensitive it will return the same string. If case insentive it will return the common object. If the user does not exist it will return null;- Parameters:
caseSensitiveUserName- String- Returns:
- String
-
countPeople
Counts the number of persons registered with the system.- Returns:
- int
-
isEnabled
Is the specified user, enabled- Returns:
- true = enabled.
- Throws:
NoSuchPersonException- if the user doesn't exist
-
getPeople(List, boolean, List, PagingRequest)