Class SpacePermissionCoordinator
- All Implemented Interfaces:
SpacePermissionManagerInternal
,SpacePermissionSaverInternal
,SpacePermissionManager
,SpacePermissionSaver
PermissionManager
and SetSpacePermissionChecker
before forwarding the call to the underlying space permission manager.-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
void
void
getAllPermissionsForGroup
(String group) Returns the default global permissions that are created when Confluence is set up.getGlobalPermissions
(String permissionType) getGroupsForPermissionType
(String permissionType, Space space) Collection<com.atlassian.user.Group>
getGroupsWithPermissions
(@Nullable Space space) Returns all groups which have permissions in a space or on a global level.Get all permissions granted to the anonymous users in the given spacegetPermissionsForGroup
(String group, Space space) Get all permissions for the given group in the specified spacegetPermissionsForUser
(ConfluenceUser user, Space space) Get all permissions for the given user in the specified spacegetUsersForPermissionType
(String permissionType, Space space) Collection<com.atlassian.user.User>
getUsersWithPermissions
(@Nullable Space space) Returns a collection of user objects with VIEWSPACE_PERMISSION in the space.boolean
groupHasPermission
(String permissionType, @Nullable Space space, String group) Checks whether the given group has the given permissionboolean
groupInheritsPermission
(String permissionType, @Nullable Space space, String group) Checks whether the given group inherits the given permission and not has it directly.boolean
hasAllPermissions
(List<String> permissionTypes, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Determines if remoteUser has all of the given permissions in spaceboolean
hasPermission
(String permissionType, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Determines if remoteUser has the given permission in spaceboolean
hasPermissionForSpace
(@Nullable ConfluenceUser user, List permissionTypes, @Nullable Space space) boolean
hasPermissionNoExemptions
(String permissionType, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Returns true if the user has the specified permission on the target space.boolean
hasPermissionNoExemptionsExceptViaNestedGroups
(String permissionType, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Returns true if the user has the specified permission on the target space except if it gets it from some parent of its parent group.boolean
isPermittedInReadOnlyAccessMode
(String permissionType) Check if the permission type is permitted in read only access modeboolean
permissionExists
(SpacePermission permission) Check whether the given SpacePermission exists.void
removeAllPermissions
(Space space) Deprecated.void
removeAllPermissions
(Space space, SpacePermissionContext context) Removes allSpacePermission
's from the specified space.void
removeAllPermissionsForGroup
(String groupName) Removes all theSpacePermission
's for the specified group.void
removeAllPermissionsForGroup
(String groupName, SpacePermissionContext context) Removes all permissions for the given group.void
removeAllUserPermissions
(@NonNull ConfluenceUser user) Removes all theSpacePermission
's for the specified user.void
removeAllUserPermissions
(ConfluenceUser user, SpacePermissionContext context) Removes all theSpacePermission
's for the specified user.void
removeGlobalPermissionForUser
(ConfluenceUser user, String permissionType) Removes the specified Global Permissions of type 'permissionType' from the uservoid
removeGlobalPermissionForUser
(ConfluenceUser user, String permissionType, SpacePermissionContext context) Removes the specified Global Permissions of type 'permissionType' from the uservoid
removePermission
(SpacePermission permission) Deprecated.void
removePermission
(SpacePermission permission, SpacePermissionContext context) Removes the specified permission.void
removePermissions
(Collection<SpacePermission> permissionsToRemove, SpacePermissionContext context) Removes the given permissions.void
saveGlobalPermissions
(Collection<SpacePermission> spacePermissions, SpacePermissionContext context) Adds global permissionsvoid
savePermission
(SpacePermission permission) Deprecated.void
savePermission
(SpacePermission permission, SpacePermissionContext context) Saves the permission.void
saveSpacePermissions
(Space space, Collection<SpacePermission> spacePermissions, SpacePermissionContext context) Adds space permissions to the spacevoid
setGroupManager
(com.atlassian.user.GroupManager groupManager) void
setPermissionManager
(PermissionManager permissionManager) void
setSetSpacePermissionChecker
(SetSpacePermissionChecker setSpacePermissionChecker) void
setSpacePermissionManager
(SpacePermissionManagerInternal spacePermissionManager) void
setUserManager
(com.atlassian.user.UserManager unused) Deprecated.since 7.7 unusedMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.atlassian.confluence.security.SpacePermissionManager
hasAllPermissions, hasPermission, hasPermissionForSpace, hasPermissionNoExemptions
-
Constructor Details
-
SpacePermissionCoordinator
public SpacePermissionCoordinator()
-
-
Method Details
-
savePermission
Deprecated.Saves the specified permission.- Specified by:
savePermission
in interfaceSpacePermissionSaver
- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckSetSpacePermissionChecker.canSetPermission(User, SpacePermission)
first.
-
savePermission
Description copied from interface:SpacePermissionSaverInternal
Saves the permission.May generate a
SpacePermissionSaveEvent
in the process, depending on the context.- Specified by:
savePermission
in interfaceSpacePermissionSaverInternal
- Parameters:
permission
- the permission to savecontext
- the context for the save
-
saveSpacePermissions
public void saveSpacePermissions(Space space, Collection<SpacePermission> spacePermissions, SpacePermissionContext context) Description copied from interface:SpacePermissionSaverInternal
Adds space permissions to the space- Specified by:
saveSpacePermissions
in interfaceSpacePermissionSaverInternal
- Parameters:
space
- Space to which permissions should be grantedspacePermissions
- Collection of space permissions. They should all belong to the same space.context
- the context of the save
-
saveGlobalPermissions
public void saveGlobalPermissions(Collection<SpacePermission> spacePermissions, SpacePermissionContext context) Description copied from interface:SpacePermissionSaverInternal
Adds global permissions- Specified by:
saveGlobalPermissions
in interfaceSpacePermissionSaverInternal
- Parameters:
spacePermissions
- Collection of global permissions.context
- the context of the save
-
removeAllPermissions
Deprecated.Removes allSpacePermission
's from the specified space.- Specified by:
removeAllPermissions
in interfaceSpacePermissionManager
- Parameters:
space
- The space to remove the permissions for- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
onPermissionManager
first.
-
removeAllPermissions
Removes allSpacePermission
's from the specified space.- Specified by:
removeAllPermissions
in interfaceSpacePermissionManagerInternal
- Parameters:
space
- The space to remove the permissions forcontext
- The context for this removal- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
onPermissionManager
first.
-
removePermission
Deprecated.Removes the specified permission.- Specified by:
removePermission
in interfaceSpacePermissionManager
- Parameters:
permission
- the permission to remove- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckSetSpacePermissionChecker.canSetPermission(User, SpacePermission)
first.
-
removePermission
Removes the specified permission.- Specified by:
removePermission
in interfaceSpacePermissionManagerInternal
- Parameters:
permission
- the permission to removecontext
- the context for the removal- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckSetSpacePermissionChecker.canSetPermission(User, SpacePermission)
first.
-
removePermissions
public void removePermissions(Collection<SpacePermission> permissionsToRemove, SpacePermissionContext context) Description copied from interface:SpacePermissionManagerInternal
Removes the given permissions.May generate a
SpacePermissionRemoveEvent
in the process, depending on the context.- Specified by:
removePermissions
in interfaceSpacePermissionManagerInternal
- Parameters:
permissionsToRemove
- the permissions to removecontext
- the context for the removal
-
createDefaultSpacePermissions
- Specified by:
createDefaultSpacePermissions
in interfaceSpacePermissionManager
-
createPrivateSpacePermissions
- Specified by:
createPrivateSpacePermissions
in interfaceSpacePermissionManager
-
removeAllUserPermissions
Removes all theSpacePermission
's for the specified user.- Specified by:
removeAllUserPermissions
in interfaceSpacePermissionManager
- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
usingPermissionManager
first.
-
removeAllUserPermissions
Removes all theSpacePermission
's for the specified user.- Specified by:
removeAllUserPermissions
in interfaceSpacePermissionManagerInternal
- Parameters:
user
- the user to remove permissions forcontext
- the context for the removal- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
usingPermissionManager
first.
-
removeGlobalPermissionForUser
Removes the specified Global Permissions of type 'permissionType' from the user- Specified by:
removeGlobalPermissionForUser
in interfaceSpacePermissionManager
- Parameters:
user
- the user to look uppermissionType
- the permission type to remove- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
usingPermissionManager
first.
-
removeGlobalPermissionForUser
public void removeGlobalPermissionForUser(ConfluenceUser user, String permissionType, SpacePermissionContext context) Removes the specified Global Permissions of type 'permissionType' from the user- Specified by:
removeGlobalPermissionForUser
in interfaceSpacePermissionManagerInternal
- Parameters:
user
- the user to look uppermissionType
- the permission type to removecontext
- the context for the removal- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
usingPermissionManager
first.
-
removeAllPermissionsForGroup
Removes all theSpacePermission
's for the specified group.- Specified by:
removeAllPermissionsForGroup
in interfaceSpacePermissionManager
- Parameters:
groupName
- the group to remove- Throws:
InsufficientPrivilegeException
- if the current logged in user does not have sufficient permissions to do this. CheckPermission.SET_PERMISSIONS
usingPermissionManager
first.EntityRuntimeException
- if there is an error retrieving the group with the specified group name
-
removeAllPermissionsForGroup
Description copied from interface:SpacePermissionManagerInternal
Removes all permissions for the given group.May generate a
SpacePermissionsRemoveForGroupEvent
in the process, depending on the context.- Specified by:
removeAllPermissionsForGroup
in interfaceSpacePermissionManagerInternal
- Parameters:
groupName
- the group to remove
-
hasPermission
public boolean hasPermission(String permissionType, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Description copied from interface:SpacePermissionManager
Determines if remoteUser has the given permission in spaceUnless you're writing code that is part of the permission checking implementation, or you're changing space permissions, you should be using
PermissionManager
instead.- Specified by:
hasPermission
in interfaceSpacePermissionManager
- Parameters:
permissionType
- The permission type to look upspace
- The space the permission applies to (can be null for global permissions)- Returns:
- true if remoteUser has the permission, false otherwise
-
hasPermissionNoExemptions
public boolean hasPermissionNoExemptions(String permissionType, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Description copied from interface:SpacePermissionManager
Returns true if the user has the specified permission on the target space. This method does not allow exemptions for super-users likeSpacePermissionManager.hasPermission(String, Space, User)
does.For parameter and return value information, see
SpacePermissionManager.hasPermission(String, Space, User)
.- Specified by:
hasPermissionNoExemptions
in interfaceSpacePermissionManager
-
hasPermissionNoExemptionsExceptViaNestedGroups
public boolean hasPermissionNoExemptionsExceptViaNestedGroups(String permissionType, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Description copied from interface:SpacePermissionManager
Returns true if the user has the specified permission on the target space except if it gets it from some parent of its parent group. This method does not allow exemptions for super-users likeSpacePermissionManager.hasPermission(String, Space, User)
does.For parameter and return value information, see
SpacePermissionManager.hasPermission(String, Space, User)
.- Specified by:
hasPermissionNoExemptionsExceptViaNestedGroups
in interfaceSpacePermissionManager
-
hasAllPermissions
public boolean hasAllPermissions(List<String> permissionTypes, @Nullable Space space, @Nullable ConfluenceUser remoteUser) Description copied from interface:SpacePermissionManager
Determines if remoteUser has all of the given permissions in spaceIf remoteUser lacks any of the given permissions, false is returned.
Unless you're writing code that is part of the permission checking implementation, or you're changing space permissions, you should be using
PermissionManager
instead.- Specified by:
hasAllPermissions
in interfaceSpacePermissionManager
- Parameters:
permissionTypes
- A List of permission types (see SpacePermission) to checkspace
- The space the permissions apply toremoteUser
- The user to look up- Returns:
- true if remoteUser has the permission, false otherwise
-
getAllPermissionsForGroup
- Specified by:
getAllPermissionsForGroup
in interfaceSpacePermissionManager
-
getGlobalPermissions
- Specified by:
getGlobalPermissions
in interfaceSpacePermissionManager
-
getGlobalPermissions
- Specified by:
getGlobalPermissions
in interfaceSpacePermissionManager
-
flushCaches
public void flushCaches()- Specified by:
flushCaches
in interfaceSpacePermissionManager
-
groupHasPermission
Description copied from interface:SpacePermissionManager
Checks whether the given group has the given permissionIf a null space is specified, this method looks up matching global permissions, otherwise space's permissions list is queried to see if the permission matches.
Similarly, if permissionType is not a space permission, a matching global permission is looked up.
- Specified by:
groupHasPermission
in interfaceSpacePermissionManager
- Parameters:
permissionType
- The permission type to look upspace
- The space the permission applies to (can be null for global permissions)group
- The group to look up the permission for- Returns:
- true if the group has the required permission, false otherwise
-
hasPermissionForSpace
public boolean hasPermissionForSpace(@Nullable ConfluenceUser user, List permissionTypes, @Nullable Space space) - Specified by:
hasPermissionForSpace
in interfaceSpacePermissionManager
-
getGroupsWithPermissions
Description copied from interface:SpacePermissionManager
Returns all groups which have permissions in a space or on a global level. If space is null, permissions on the global level will be checked.- Specified by:
getGroupsWithPermissions
in interfaceSpacePermissionManager
- Parameters:
space
- - space to query, if null global permissions returned- Returns:
- Collection of groups with permissions
-
getGroupsForPermissionType
- Specified by:
getGroupsForPermissionType
in interfaceSpacePermissionManager
-
getUsersWithPermissions
Description copied from interface:SpacePermissionManager
Returns a collection of user objects with VIEWSPACE_PERMISSION in the space. If no space is provided A list of users with USE_CONFLUENCE_PERMISSION will be returned- Specified by:
getUsersWithPermissions
in interfaceSpacePermissionManager
- Parameters:
space
- - space to query, if null global permissions returned- Returns:
- Collection of User objects
-
getUsersForPermissionType
- Specified by:
getUsersForPermissionType
in interfaceSpacePermissionManager
-
permissionExists
Description copied from interface:SpacePermissionManager
Check whether the given SpacePermission exists. Checks by attribute equality rather than by id.- Specified by:
permissionExists
in interfaceSpacePermissionManager
- Parameters:
permission
- the permission to look for.- Returns:
- true if the permission is recognised by the manager as existing.
-
getDefaultGlobalPermissions
Description copied from interface:SpacePermissionManager
Returns the default global permissions that are created when Confluence is set up. These will exist in a newly set up system but may be removed afterwards. Note that the returned objects are freshly created and therefore do not have IDs or other persistence data.By default, confluence-administrators group has admin access, the default confluence users group can view the system and anonymous access is disabled.
- Specified by:
getDefaultGlobalPermissions
in interfaceSpacePermissionManager
- Returns:
- a collection of
SpacePermission
s.
-
isPermittedInReadOnlyAccessMode
Description copied from interface:SpacePermissionManager
Check if the permission type is permitted in read only access mode- Specified by:
isPermittedInReadOnlyAccessMode
in interfaceSpacePermissionManager
- Parameters:
permissionType
- the permission type to be checked- Returns:
- true if the permission type is permitted in read only access mode
-
getPermissionsForUser
Description copied from interface:SpacePermissionManager
Get all permissions for the given user in the specified space- Specified by:
getPermissionsForUser
in interfaceSpacePermissionManager
- Parameters:
user
- the user to look upspace
- the space entity- Returns:
- a list of space permissions granted to the user in the given space
-
getPermissionsForGroup
Description copied from interface:SpacePermissionManager
Get all permissions for the given group in the specified space- Specified by:
getPermissionsForGroup
in interfaceSpacePermissionManager
- Parameters:
group
- the name of the groupspace
- the space entity- Returns:
- a list of space permissions granted to the group in the given space
-
getPermissionsForAnonymousUsers
Description copied from interface:SpacePermissionManager
Get all permissions granted to the anonymous users in the given space- Specified by:
getPermissionsForAnonymousUsers
in interfaceSpacePermissionManager
- Parameters:
space
- the space entity- Returns:
- a list of space permissions granted to anonymous users in the given space
-
groupInheritsPermission
Description copied from interface:SpacePermissionManager
Checks whether the given group inherits the given permission and not has it directly.If a null space is specified, this method looks up matching global permissions, otherwise space's permissions list is queried to see if the permission matches.
Similarly, if permissionType is not a space permission, a matching global permission is looked up.
- Specified by:
groupInheritsPermission
in interfaceSpacePermissionManager
- Parameters:
permissionType
- The permission type to look upspace
- The space the permission applies to (can be null for global permissions)group
- The group to look up the permission for- Returns:
- true only if the group inherits the required permission and not has it directly, false otherwise
-
setPermissionManager
-
setSpacePermissionManager
-
setSetSpacePermissionChecker
-
setUserManager
Deprecated.since 7.7 unused -
setGroupManager
public void setGroupManager(com.atlassian.user.GroupManager groupManager)
-