mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
RM: Run copy of permissions as Admin to allow records managers to copy record folders and records
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@16641 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -44,6 +44,7 @@ import org.alfresco.repo.copy.CopyBehaviourCallback.CopyChildAssociationDetails;
|
|||||||
import org.alfresco.repo.policy.ClassPolicyDelegate;
|
import org.alfresco.repo.policy.ClassPolicyDelegate;
|
||||||
import org.alfresco.repo.policy.JavaBehaviour;
|
import org.alfresco.repo.policy.JavaBehaviour;
|
||||||
import org.alfresco.repo.policy.PolicyComponent;
|
import org.alfresco.repo.policy.PolicyComponent;
|
||||||
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||||
import org.alfresco.service.cmr.dictionary.AspectDefinition;
|
import org.alfresco.service.cmr.dictionary.AspectDefinition;
|
||||||
import org.alfresco.service.cmr.dictionary.AssociationDefinition;
|
import org.alfresco.service.cmr.dictionary.AssociationDefinition;
|
||||||
import org.alfresco.service.cmr.dictionary.ChildAssociationDefinition;
|
import org.alfresco.service.cmr.dictionary.ChildAssociationDefinition;
|
||||||
@@ -687,32 +688,41 @@ public class CopyServiceImpl implements CopyService
|
|||||||
* @param sourceNodeRef the source node reference
|
* @param sourceNodeRef the source node reference
|
||||||
* @param destinationNodeRef the destination node reference
|
* @param destinationNodeRef the destination node reference
|
||||||
*/
|
*/
|
||||||
private void copyPermissions(NodeRef sourceNodeRef, NodeRef destinationNodeRef)
|
private void copyPermissions(final NodeRef sourceNodeRef, final NodeRef destinationNodeRef)
|
||||||
{
|
{
|
||||||
if(this.permissionService.hasPermission(sourceNodeRef, PermissionService.READ_PERMISSIONS) == AccessStatus.ALLOWED)
|
AuthenticationUtil.runAs(new AuthenticationUtil.RunAsWork<Object>()
|
||||||
|
{
|
||||||
|
public Object doWork() throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
if(permissionService.hasPermission(sourceNodeRef, PermissionService.READ_PERMISSIONS) == AccessStatus.ALLOWED)
|
||||||
{
|
{
|
||||||
// Get the permission details of the source node reference
|
// Get the permission details of the source node reference
|
||||||
Set<AccessPermission> permissions = this.permissionService.getAllSetPermissions(sourceNodeRef);
|
Set<AccessPermission> permissions = permissionService.getAllSetPermissions(sourceNodeRef);
|
||||||
boolean includeInherited = this.permissionService.getInheritParentPermissions(sourceNodeRef);
|
boolean includeInherited = permissionService.getInheritParentPermissions(sourceNodeRef);
|
||||||
|
|
||||||
AccessStatus writePermission = permissionService.hasPermission(destinationNodeRef, PermissionService.CHANGE_PERMISSIONS);
|
AccessStatus writePermission = permissionService.hasPermission(destinationNodeRef, PermissionService.CHANGE_PERMISSIONS);
|
||||||
if (writePermission.equals(AccessStatus.ALLOWED) || this.authenticationService.isCurrentUserTheSystemUser() )
|
if (writePermission.equals(AccessStatus.ALLOWED) || authenticationService.isCurrentUserTheSystemUser() )
|
||||||
{
|
{
|
||||||
// Set the permission values on the destination node
|
// Set the permission values on the destination node
|
||||||
for (AccessPermission permission : permissions)
|
for (AccessPermission permission : permissions)
|
||||||
{
|
{
|
||||||
if(permission.isSetDirectly())
|
if(permission.isSetDirectly())
|
||||||
{
|
{
|
||||||
this.permissionService.setPermission(
|
permissionService.setPermission(
|
||||||
destinationNodeRef,
|
destinationNodeRef,
|
||||||
permission.getAuthority(),
|
permission.getAuthority(),
|
||||||
permission.getPermission(),
|
permission.getPermission(),
|
||||||
permission.getAccessStatus().equals(AccessStatus.ALLOWED));
|
permission.getAccessStatus().equals(AccessStatus.ALLOWED));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.permissionService.setInheritParentPermissions(destinationNodeRef, includeInherited);
|
permissionService.setInheritParentPermissions(destinationNodeRef, includeInherited);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}, AuthenticationUtil.getAdminUserName());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Reference in New Issue
Block a user