Class PrivilegeRegistry
- java.lang.Object
-
- org.apache.jackrabbit.core.security.authorization.PrivilegeRegistry
-
- All Implemented Interfaces:
PrivilegeEventListener
public final class PrivilegeRegistry extends Object implements PrivilegeEventListener
ThePrivilegeRegistry
defines the set ofPrivilege
s known to the repository.
-
-
Field Summary
Fields Modifier and Type Field Description static int
NO_PRIVILEGE
No privilegesstatic String
REP_PRIVILEGE_MANAGEMENT
Jackrabbit specific privilege for privilege management.static Name
REP_PRIVILEGE_MANAGEMENT_NAME
static String
REP_WRITE
Jackrabbit specific write privilege that combinesPrivilege.JCR_WRITE
andPrivilege.JCR_NODE_TYPE_MANAGEMENT
.static Name
REP_WRITE_NAME
-
Constructor Summary
Constructors Constructor Description PrivilegeRegistry(NamespaceRegistry namespaceRegistry, FileSystem fs)
Create a newPrivilegeRegistry
instance.PrivilegeRegistry(NameResolver resolver)
Deprecated.UsePrivilegeManager
instead.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description static int
calculatePermissions(int privs, int parentPrivs, boolean isAllow, boolean protectsPolicy)
Deprecated.static int
calculatePermissions(PrivilegeBits privs, PrivilegeBits parentPrivs, boolean isAllow, boolean protectsPolicy)
Build the permissions granted by evaluating the given privileges.void
externalRegisteredPrivileges(Collection<PrivilegeDefinition> definitions)
Called when one or more privilege definitions have been externally registered.static int
getBits(Privilege[] privileges)
Deprecated.Privilege
getPrivilege(String privilegeName)
Deprecated.UsePrivilegeManager.getPrivilege(String)
instead.Privilege[]
getPrivileges(int bits)
Deprecated.UsePrivilegeManagerImpl.getPrivileges(PrivilegeBits)
instead.Privilege[]
getRegisteredPrivileges()
Deprecated.UsePrivilegeManager.getRegisteredPrivileges()
instead.void
removeListener(org.apache.jackrabbit.core.security.authorization.PrivilegeRegistry.Listener listener)
Removes a privilege registration listener.void
setEventChannel(PrivilegeEventChannel eventChannel)
Set a clustering event channel to inform about changes.
-
-
-
Field Detail
-
REP_WRITE
public static final String REP_WRITE
Jackrabbit specific write privilege that combinesPrivilege.JCR_WRITE
andPrivilege.JCR_NODE_TYPE_MANAGEMENT
.- See Also:
- Constant Field Values
-
REP_WRITE_NAME
public static final Name REP_WRITE_NAME
-
REP_PRIVILEGE_MANAGEMENT
public static final String REP_PRIVILEGE_MANAGEMENT
Jackrabbit specific privilege for privilege management.- See Also:
- Constant Field Values
-
REP_PRIVILEGE_MANAGEMENT_NAME
public static final Name REP_PRIVILEGE_MANAGEMENT_NAME
-
NO_PRIVILEGE
public static final int NO_PRIVILEGE
No privileges- See Also:
- Constant Field Values
-
-
Constructor Detail
-
PrivilegeRegistry
public PrivilegeRegistry(NamespaceRegistry namespaceRegistry, FileSystem fs) throws RepositoryException
Create a newPrivilegeRegistry
instance.- Parameters:
namespaceRegistry
-fs
-- Throws:
RepositoryException
-
PrivilegeRegistry
public PrivilegeRegistry(NameResolver resolver)
Deprecated.UsePrivilegeManager
instead.Create a newPrivilegeRegistry
instance defining only built-in privileges.- Parameters:
resolver
-- See Also:
JackrabbitWorkspace.getPrivilegeManager()
-
-
Method Detail
-
externalRegisteredPrivileges
public void externalRegisteredPrivileges(Collection<PrivilegeDefinition> definitions) throws RepositoryException
Called when one or more privilege definitions have been externally registered.- Specified by:
externalRegisteredPrivileges
in interfacePrivilegeEventListener
- Parameters:
definitions
- privilege definitions- Throws:
RepositoryException
- if an error occurs- See Also:
PrivilegeEventListener.externalRegisteredPrivileges(java.util.Collection)
-
setEventChannel
public void setEventChannel(PrivilegeEventChannel eventChannel)
Set a clustering event channel to inform about changes.- Parameters:
eventChannel
- event channel
-
getRegisteredPrivileges
public Privilege[] getRegisteredPrivileges()
Deprecated.UsePrivilegeManager.getRegisteredPrivileges()
instead.ThrowsUnsupportedOperationException
.- Returns:
- all registered privileges.
-
getPrivilege
public Privilege getPrivilege(String privilegeName) throws AccessControlException, RepositoryException
Deprecated.UsePrivilegeManager.getPrivilege(String)
instead.Creates a newPrivilegeManager
from the specified resolver and callsPrivilegeManagerImpl.getRegisteredPrivileges()
.- Parameters:
privilegeName
- Name of the privilege.- Returns:
- the privilege with the specified
privilegeName
. - Throws:
AccessControlException
- If no privilege with the given name exists.RepositoryException
- If another error occurs.
-
getPrivileges
public Privilege[] getPrivileges(int bits)
Deprecated.UsePrivilegeManagerImpl.getPrivileges(PrivilegeBits)
instead.Creates a newPrivilegeManager
from the specified resolver and callsPrivilegeManagerImpl.getPrivileges(PrivilegeBits)
.- Parameters:
bits
- Privilege bits as obtained fromgetBits(Privilege[])
.- Returns:
- Array of
Privilege
s that are presented by the given it or an empty array ifbits
is lower thanREAD
or cannot be resolved to registeredPrivilege
s. - See Also:
getBits(Privilege[])
-
getBits
public static int getBits(Privilege[] privileges) throws AccessControlException
Deprecated.Best effort approach to calculate bits for built-in privileges. ThrowsUnsupportedOperationException
if the workaround fails.- Parameters:
privileges
- An array of privileges.- Returns:
- The privilege bits.
- Throws:
AccessControlException
- If the specified array is null or if it contains an unregistered privilege.- See Also:
getPrivileges(int)
-
calculatePermissions
public static int calculatePermissions(PrivilegeBits privs, PrivilegeBits parentPrivs, boolean isAllow, boolean protectsPolicy)
Build the permissions granted by evaluating the given privileges. Note, that only built-in privileges can be mapped to permissions. Any other privileges will be ignored.- Parameters:
privs
- The privileges granted on the Node itself (for properties the ACL of the direct ancestor).parentPrivs
- The privileges granted on the parent of the Node. Not relevant for properties since it only is used to determine permissions on a Node (add_child_nodes, remove_child_nodes).isAllow
-true
if the privileges are granted;false
otherwise.protectsPolicy
- Iftrue
the affected item itself defines access control related information.- Returns:
- the permissions granted evaluating the given privileges.
-
calculatePermissions
public static int calculatePermissions(int privs, int parentPrivs, boolean isAllow, boolean protectsPolicy)
Deprecated.Build the permissions granted by evaluating the given privileges. Note, that only built-in privileges can be mapped to permissions. Any other privileges will be ignored.- Parameters:
privs
- The privileges granted on the Node itself (for properties the ACL of the direct ancestor).parentPrivs
- The privileges granted on the parent of the Node. Not relevant for properties since it only is used to determine permissions on a Node (add_child_nodes, remove_child_nodes).isAllow
-true
if the privileges are granted;false
otherwise.protectsPolicy
- Iftrue
the affected item itself defines access control related information.- Returns:
- the permissions granted evaluating the given privileges.
-
removeListener
public void removeListener(org.apache.jackrabbit.core.security.authorization.PrivilegeRegistry.Listener listener)
Removes a privilege registration listener.- Parameters:
listener
-
-
-