@AlfrescoPublicApi
public interface AuthorityService
Modifier and Type | Interface and Description |
---|---|
static interface |
AuthorityService.AuthorityFilter |
Modifier and Type | Field and Description |
---|---|
static String |
ZONE_APP_DEFAULT
The default application zone.
|
static String |
ZONE_APP_SHARE
The SHARE application zone.
|
static String |
ZONE_AUTH_ALFRESCO
Default authentication
|
static String |
ZONE_AUTH_EXT_PREFIX
Prefix for external auth ids
|
Modifier and Type | Method and Description |
---|---|
void |
addAuthority(Collection<String> parentNames,
String childName)
Set a given child authority to be included by the given parent authorities.
|
void |
addAuthority(String parentName,
String childName)
Set an authority to include another authority.
|
void |
addAuthorityToZones(String authorityName,
Set<String> zones)
Add a zone to an authority.
|
boolean |
authorityExists(String name)
Check if an authority exists.
|
long |
countGroups()
Count the number of users (not groups)
|
long |
countUsers()
Count the number of groups
|
String |
createAuthority(org.alfresco.service.cmr.security.AuthorityType type,
String shortName)
Create an authority.
|
String |
createAuthority(org.alfresco.service.cmr.security.AuthorityType type,
String shortName,
String authorityDisplayName,
Set<String> authorityZones)
Create an authority with a display name and zone.
|
void |
deleteAuthority(String name)
Delete an authority and all its relationships.
|
void |
deleteAuthority(String name,
boolean cascade)
Delete an authority and all its relationships, optionally recursively deleting child authorities of the same
type.
|
Set<String> |
findAuthorities(org.alfresco.service.cmr.security.AuthorityType type,
String parentAuthority,
boolean immediate,
String displayNamePattern,
String zoneName)
Search for authorities by pattern matching (* and ?) against the authority name.
|
Set<String> |
getAllAuthorities(org.alfresco.service.cmr.security.AuthorityType type)
Deprecated.
|
Set<String> |
getAllAuthoritiesInZone(String zoneName,
org.alfresco.service.cmr.security.AuthorityType type)
Gets the names of all authorities in a zone, optionally filtered by type
See also "getAuthorities" paged alternative (note: in that case, zone must exist)
|
Set<String> |
getAllRootAuthorities(org.alfresco.service.cmr.security.AuthorityType type)
Get all root authorities by type.
|
Set<String> |
getAllRootAuthoritiesInZone(String zoneName,
org.alfresco.service.cmr.security.AuthorityType type)
Gets the names of all root authorities in a zone, optionally filtered by type.
|
Set<String> |
getAuthorities()
Get the authorities for the current user
|
org.alfresco.query.PagingResults<String> |
getAuthorities(org.alfresco.service.cmr.security.AuthorityType type,
String zoneName,
String displayNameFilter,
boolean sortByDisplayName,
boolean sortAscending,
org.alfresco.query.PagingRequest pagingRequest)
Get authorities by type and/or zone
|
Set<String> |
getAuthoritiesForUser(String userName)
Get the authorities for the given user
|
org.alfresco.query.PagingResults<AuthorityInfo> |
getAuthoritiesInfo(org.alfresco.service.cmr.security.AuthorityType type,
String zoneName,
String displayNameFilter,
String sortBy,
boolean sortAscending,
org.alfresco.query.PagingRequest pagingRequest)
Get authorities by type and/or zone
|
String |
getAuthorityDisplayName(String name)
Get the display name for the given authority.
|
org.alfresco.service.cmr.repository.NodeRef |
getAuthorityNodeRef(String name)
Gets the authority node for the specified name
|
Set<String> |
getAuthorityZones(String name)
Gets the name of the zone containing the specified authority.
|
Set<String> |
getContainedAuthorities(org.alfresco.service.cmr.security.AuthorityType type,
String name,
boolean immediate)
Get all the authorities that are contained by the given authority.
|
Set<String> |
getContainingAuthorities(org.alfresco.service.cmr.security.AuthorityType type,
String name,
boolean immediate)
Get the authorities that contain the given authority,
but use
getAuthoritiesForUser(userName).contains(authority) rather than
getContainingAuthorities(type, userName, false).contains(authority) or
use getContainingAuthoritiesInZone(AuthorityType, String, String, AuthorityFilter, int)
as they will be much faster. |
Set<String> |
getContainingAuthoritiesInZone(org.alfresco.service.cmr.security.AuthorityType type,
String name,
String zoneName,
AuthorityService.AuthorityFilter filter,
int size)
Get a set of authorities with varying filter criteria
|
Set<String> |
getDefaultZones()
Get the name of the default zone.
|
String |
getName(org.alfresco.service.cmr.security.AuthorityType type,
String shortName)
Create the full identifier for an authority given its short name and
type.
|
org.alfresco.service.cmr.repository.NodeRef |
getOrCreateZone(String zoneName)
Gets or creates an authority zone node with the specified name
|
String |
getShortName(String name)
Extract the short name of an authority from its full identifier.
|
org.alfresco.service.cmr.repository.NodeRef |
getZone(String zoneName)
Gets an authority zone node with the specified name
|
boolean |
hasAdminAuthority()
Check of the current user has admin authority.
|
boolean |
hasGuestAuthority()
Check of the current user has guest authority.
|
boolean |
isAdminAuthority(String authorityName)
Does the given authority have admin authority.
|
boolean |
isGuestAuthority(String authorityName)
Does the given authority have guest authority.
|
void |
removeAuthority(String parentName,
String childName)
Remove an authority as a member of another authority.
|
void |
removeAuthorityFromZones(String authorityName,
Set<String> zones)
Remove a zone from an authority
|
void |
setAuthorityDisplayName(String authorityName,
String authorityDisplayName)
Set the display name for the given authority.
|
static final String ZONE_APP_DEFAULT
static final String ZONE_APP_SHARE
static final String ZONE_AUTH_ALFRESCO
static final String ZONE_AUTH_EXT_PREFIX
@Auditable boolean hasAdminAuthority()
@Auditable(parameters="authorityName") boolean isAdminAuthority(String authorityName)
authorityName
- The name of the authority.@Auditable boolean hasGuestAuthority()
@Auditable(parameters="authorityName") boolean isGuestAuthority(String authorityName)
authorityName
- The name of the authority.@Auditable long countUsers()
@Auditable long countGroups()
@Auditable Set<String> getAuthorities()
@Auditable(parameters="userName") Set<String> getAuthoritiesForUser(String userName)
@Auditable(parameters="type") @Deprecated Set<String> getAllAuthorities(org.alfresco.service.cmr.security.AuthorityType type)
getAuthorities(AuthorityType, String, String, boolean, boolean, PagingRequest)
at leasttype
- the type of authorities - cannot be null(paged)
@Auditable(parameters={"type","zoneName","displayNameFilter","sortByDisplayName","sortAscending","pagingRequest"}) org.alfresco.query.PagingResults<AuthorityInfo> getAuthoritiesInfo(org.alfresco.service.cmr.security.AuthorityType type, String zoneName, String displayNameFilter, String sortBy, boolean sortAscending, org.alfresco.query.PagingRequest pagingRequest)
type
- the type of authorities (note: mandatory if zoneName is null)zoneName
- the zoneName (note: mandatory if type is null)displayNameFilter
- optional filter (startsWith / ignoreCase) for authority display name (note: implied trailing "*")sortBy
- either "displayName", "shortName", "authorityName" or null if no sorting.
note: for users, displayName/shortName is equivalent to the userName, for groups if the display is null then use the short namesortAscending
- if true then sort ascending else sort descending (ignore if sortByDisplayName is false)pagingRequest
- the requested page (skipCount, maxItems, queryExectionId)UnknownAuthorityException
- - if zoneName is not null and does not exist
@Auditable(parameters={"type","zoneName","displayNameFilter","sortByDisplayName","sortAscending","pagingRequest"}) org.alfresco.query.PagingResults<String> getAuthorities(org.alfresco.service.cmr.security.AuthorityType type, String zoneName, String displayNameFilter, boolean sortByDisplayName, boolean sortAscending, org.alfresco.query.PagingRequest pagingRequest)
type
- the type of authorities (note: mandatory if zoneName is null)zoneName
- the zoneName (note: mandatory if type is null)displayNameFilter
- optional filter (startsWith / ignoreCase) for authority display name (note: implied trailing "*")sortByDisplayName
- if true then sort (ignoring case) by the authority display name, if false then unsorted
note: for users, displayName/shortName is equivalent to the userName, for groups if the display is null then use the short namesortAscending
- if true then sort ascending else sort descending (ignore if sortByDisplayName is false)pagingRequest
- the requested page (skipCount, maxItems, queryExectionId)UnknownAuthorityException
- - if zoneName is not null and does not exist
@Auditable(parameters="type") Set<String> getAllRootAuthorities(org.alfresco.service.cmr.security.AuthorityType type)
type
- -
the type of the authority@Auditable(parameters={"type","shortName"}) String createAuthority(org.alfresco.service.cmr.security.AuthorityType type, String shortName)
type
- -
the type of the authorityshortName
- -
the short name of the authority to create
this will also be set as the default display name for the authority@Auditable(parameters={"type","shortName","authorityDisplayName","authorityZones"}) String createAuthority(org.alfresco.service.cmr.security.AuthorityType type, String shortName, String authorityDisplayName, Set<String> authorityZones)
type
- the type of the authorityshortName
- the short name of the authority to createauthorityDisplayName
- the display name for the authorityauthorityZones
- identifier for external user registry owning the authority or null
if not applicable@Auditable(parameters={"parentName","childName"}) void addAuthority(String parentName, String childName)
parentName
- -
the full name string identifier for the parent.childName
- -
the string identifier for the child.@Auditable(parameters={"parentNames","childName"}) void addAuthority(Collection<String> parentNames, String childName)
parentNames
- -
the full name string identifier for the parents.childName
- -
the string identifier for the child.@Auditable(parameters={"parentName","childName"}) void removeAuthority(String parentName, String childName)
parentName
- -
the string identifier for the parent.childName
- -
the string identifier for the child.@Auditable(parameters="name") void deleteAuthority(String name)
name
- String@Auditable(parameters={"name","cascade"}) void deleteAuthority(String name, boolean cascade)
name
- the authority long namecascade
- should the delete be cascaded to child authorities of the same type?@Auditable(parameters={"type","name","immediate"}) Set<String> getContainedAuthorities(org.alfresco.service.cmr.security.AuthorityType type, String name, boolean immediate)
type
- -
if not null, limit to the type of authority specifiedname
- -
the name of the containing authorityimmediate
- -
if true, limit the depth to just immediate child, if false
find authorities at any depth@Auditable(parameters={"type","name","immediate"}) Set<String> getContainingAuthorities(org.alfresco.service.cmr.security.AuthorityType type, String name, boolean immediate)
getAuthoritiesForUser(userName).contains(authority)
rather than
getContainingAuthorities(type, userName, false).contains(authority)
or
use getContainingAuthoritiesInZone(AuthorityType, String, String, AuthorityFilter, int)
as they will be much faster.
For example, this method can be used find out all the authorities that contain a
group.type
- -
if not null, limit to the type of authority specifiedname
- -
the name of the authority for which the containing authorities
are required.immediate
- -
limit to immediate parents or any ancestor.@Auditable(parameters={"type","name","zoneName","filter","size"}) Set<String> getContainingAuthoritiesInZone(org.alfresco.service.cmr.security.AuthorityType type, String name, String zoneName, AuthorityService.AuthorityFilter filter, int size)
type
- authority type or null for all typesname
- if non-null, only return those authorities who contain this authorityzoneName
- if non-null, only include authorities in the named zonefilter
- optional callback to apply further filter criteria or nullsize
- if greater than zero, the maximum results to return. The search strategy used is varied depending on
this number.@Auditable(parameters="name") String getShortName(String name)
name
- String@Auditable(parameters={"type","shortName"}) String getName(org.alfresco.service.cmr.security.AuthorityType type, String shortName)
type
- AuthorityTypeshortName
- String@Auditable(parameters="name") boolean authorityExists(String name)
name
- (the long name).@Auditable(parameters="name") String getAuthorityDisplayName(String name)
name
- - the full authority string including any prefix (e.g. GROUP_woof)@Auditable(parameters={"authorityName","authorityDisplayName"}) void setAuthorityDisplayName(String authorityName, String authorityDisplayName)
authorityName
- StringauthorityDisplayName
- String@Auditable(parameters="name") org.alfresco.service.cmr.repository.NodeRef getAuthorityNodeRef(String name)
name
- The authority name@Auditable(parameters="zoneName") org.alfresco.service.cmr.repository.NodeRef getOrCreateZone(String zoneName)
zoneName
- the zone name@Auditable(parameters="zoneName") org.alfresco.service.cmr.repository.NodeRef getZone(String zoneName)
zoneName
- the zone name@Auditable(parameters="name") Set<String> getAuthorityZones(String name)
name
- the authority long nameZONE_APP_DEFAULT
if the
authority exists but has no zone, or null
if the authority does not exist.@Auditable(parameters={"zoneName","type"}) Set<String> getAllAuthoritiesInZone(String zoneName, org.alfresco.service.cmr.security.AuthorityType type)
zoneName
- the zone name - note: if zone does not exist then will currently return empty settype
- the authority type to filter by or null
for all authority types(paged)
@Auditable(parameters={"zoneName","type"}) Set<String> getAllRootAuthoritiesInZone(String zoneName, org.alfresco.service.cmr.security.AuthorityType type)
zoneName
- the zone nametype
- the authority type to filter by or null
for all authority types@Auditable(parameters={"authorityName","zones"}) void addAuthorityToZones(String authorityName, Set<String> zones)
authorityName
- String@Auditable(parameters={"authorityName","zones"}) void removeAuthorityFromZones(String authorityName, Set<String> zones)
authorityName
- String@NotAuditable Set<String> getDefaultZones()
@Auditable(parameters="type") Set<String> findAuthorities(org.alfresco.service.cmr.security.AuthorityType type, String parentAuthority, boolean immediate, String displayNamePattern, String zoneName)
type
- AuthorityTypeparentAuthority
- if non-null, will look only for authorities who are a child of the named parentimmediate
- if true
then only search root groups if parentAuthority is null, or immediate children of parentAuthority if it is non-null.displayNamePattern
- StringzoneName
- - may be null to indicate all zonesCopyright © 2005–2017 Alfresco Software. All rights reserved.