public class ACLEditor extends ProtectedItemModifier implements AccessControlEditor, AccessControlConstants
ACLEditor
...N_ACCESSCONTROL, N_POLICY, N_REPO_POLICY, NT_REP_ACCESS_CONTROL, NT_REP_ACCESS_CONTROLLABLE, NT_REP_ACE, NT_REP_ACL, NT_REP_DENY_ACE, NT_REP_GRANT_ACE, NT_REP_PRINCIPAL_ACCESS_CONTROL, NT_REP_REPO_ACCESS_CONTROLLABLE, P_GLOB, P_PRINCIPAL_NAME, P_PRIVILEGES
Modifier and Type | Method and Description |
---|---|
org.apache.jackrabbit.api.security.JackrabbitAccessControlPolicy[] |
editAccessControlPolicies(Principal principal)
Returns an array of editable policies for the given
principal . |
AccessControlPolicy[] |
editAccessControlPolicies(String nodePath)
Retrieves the editable policies for the Node identified by the given
nodePath that are applicable but have not yet have been set.The AccessControlPolicy objects returned are detached from the underlying AccessControlProvider and is only an external
representation. |
org.apache.jackrabbit.api.security.JackrabbitAccessControlPolicy[] |
getPolicies(Principal principal)
Retrieves the policies that have been applied before for the given
principal . |
AccessControlPolicy[] |
getPolicies(String nodePath)
Retrieves the policies for the Node identified by the given
nodePath . |
protected static Name |
getUniqueNodeName(Node node,
String name)
Create a unique valid name for the Permission nodes to be save.
|
void |
removePolicy(String nodePath,
AccessControlPolicy policy)
Removes the specified policy from the node at
nodePath . |
void |
setPolicy(String nodePath,
AccessControlPolicy policy)
Stores the policy template to the respective node.
|
addNode, addNode, markModified, performProtected, removeItem, setProperty, setProperty, setProperty, setProperty
public AccessControlPolicy[] getPolicies(String nodePath) throws AccessControlException, PathNotFoundException, RepositoryException
AccessControlEditor
nodePath
. In contrast to AccessControlEditor.editAccessControlPolicies(java.lang.String)
this method
returns an empty array if no policy has been applied before by calling
AccessControlEditor.setPolicy(java.lang.String, javax.jcr.security.AccessControlPolicy)
). Still the returned policies are detached from
the AccessControlProvider
and are only an external representation.
Modification will therefore not take effect, until they are written back to
the editor and persisted.
Compared to the policy returned by AccessControlProvider.getEffectivePolicies(org.apache.jackrabbit.spi.Path, CompiledPermissions)
,
the scope of the policies it limited to the Node itself and does
not take inherited elements into account.
getPolicies
in interface AccessControlEditor
nodePath
- Absolute path to an existing node object.AccessControlException
- If the Node identified by the given
nodePath
does not allow access control modifications (e.g.
the node itself stores the access control information for its parent).PathNotFoundException
- if no node exists for the given
nodePath
.RepositoryException
- if an error occursAccessControlEditor.getPolicies(String)
public org.apache.jackrabbit.api.security.JackrabbitAccessControlPolicy[] getPolicies(Principal principal) throws AccessControlException, RepositoryException
AccessControlEditor
principal
. In contrast to AccessControlEditor.editAccessControlPolicies(java.lang.String)
this method returns an empty array if no policy has been applied before
by calling AccessControlEditor.setPolicy(java.lang.String, javax.jcr.security.AccessControlPolicy)
). Still the returned policies are detached from
the AccessControlProvider
and are only an external representation.
Modification will therefore not take effect, until they are written back to
the editor and persisted.getPolicies
in interface AccessControlEditor
principal
- Principal for which the editable policies should be
returned.AccessControlException
- if the specified principal does not exist,
if this implementation cannot provide policies for individual principals or
if same other access control related exception occurs.RepositoryException
- if an error occursAccessControlEditor.getPolicies(Principal)
public AccessControlPolicy[] editAccessControlPolicies(String nodePath) throws AccessControlException, PathNotFoundException, RepositoryException
AccessControlEditor
nodePath
that are applicable but have not yet have been set.AccessControlProvider
and is only an external
representation. Modification will therefore not take effect, until a
modified policy is written back to the editor and persisted.
See AccessControlEditor.getPolicies(String)
for the corresponding method that returns
the editable policies that have been set to the node at
nodePath
before.
Compared to the policies returned by AccessControlProvider.getEffectivePolicies(org.apache.jackrabbit.spi.Path, CompiledPermissions)
,
the scope of the policies returned by this methods it limited to the Node
itself and does never not take inherited elements into account.
editAccessControlPolicies
in interface AccessControlEditor
nodePath
- Absolute path to an existing node object.AccessControlException
- If the Node identified by the given
nodePath
does not allow access control modifications.PathNotFoundException
- if no node exists for the given
nodePath
.RepositoryException
- if an error occursAccessControlEditor.editAccessControlPolicies(String)
public org.apache.jackrabbit.api.security.JackrabbitAccessControlPolicy[] editAccessControlPolicies(Principal principal) throws RepositoryException
AccessControlEditor
principal
.editAccessControlPolicies
in interface AccessControlEditor
principal
- Principal for which the editable policies should be
returned.principal
.AccessDeniedException
- If the editing session is not allowed to
edit policies.AccessControlException
- if the specified principal does not exist,
if this implementation cannot provide policies for individual principals or
if same other access control related exception occurs.RepositoryException
- if another error occurs.AccessControlEditor.editAccessControlPolicies(Principal)
public void setPolicy(String nodePath, AccessControlPolicy policy) throws AccessControlException, PathNotFoundException, RepositoryException
AccessControlEditor
setPolicy
in interface AccessControlEditor
nodePath
- Absolute path to an existing node object.policy
- the AccessControlPolicy
to store.AccessControlException
- If the policy is null
or
if it is not applicable to the Node identified by the given
nodePath
.PathNotFoundException
- if no node exists for the given
nodePath
.RepositoryException
- if an other error occurs.AccessControlEditor.setPolicy(String,AccessControlPolicy)
public void removePolicy(String nodePath, AccessControlPolicy policy) throws AccessControlException, PathNotFoundException, RepositoryException
AccessControlEditor
nodePath
.removePolicy
in interface AccessControlEditor
nodePath
- Absolute path to an existing node object.policy
- The policy to be removed at nodePath
.AccessControlException
- If the Node identified by the given
nodePath
does not allow policy modifications or does not have
the specified policy attached.PathNotFoundException
- if no node exists for the given
nodePath
.RepositoryException
- if an other error occursAccessControlEditor.removePolicy(String,AccessControlPolicy)
protected static Name getUniqueNodeName(Node node, String name) throws RepositoryException
node
- a name for the child is resolvedname
- if missing the DEFAULT_ACE_NAME
is takenRepositoryException
- if an error occursCopyright © 2004–2024 The Apache Software Foundation. All rights reserved.