mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
[RM-885] Copy action works incorrectly for folders and subcategories. Add policy to not allow copy record folder into another record folder.
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/HEAD@54724 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -18,6 +18,7 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.model.behaviour;
|
package org.alfresco.module.org_alfresco_module_rm.model.behaviour;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@@ -27,8 +28,10 @@ import org.alfresco.module.org_alfresco_module_rm.RecordsManagementServiceRegist
|
|||||||
import org.alfresco.module.org_alfresco_module_rm.action.RecordsManagementActionService;
|
import org.alfresco.module.org_alfresco_module_rm.action.RecordsManagementActionService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.identifier.IdentifierService;
|
import org.alfresco.module.org_alfresco_module_rm.identifier.IdentifierService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
||||||
|
import org.alfresco.repo.copy.AbstractCopyBehaviourCallback;
|
||||||
import org.alfresco.repo.copy.CopyBehaviourCallback;
|
import org.alfresco.repo.copy.CopyBehaviourCallback;
|
||||||
import org.alfresco.repo.copy.CopyDetails;
|
import org.alfresco.repo.copy.CopyDetails;
|
||||||
|
import org.alfresco.repo.copy.DefaultCopyBehaviourCallback;
|
||||||
import org.alfresco.repo.copy.DoNothingCopyBehaviourCallback;
|
import org.alfresco.repo.copy.DoNothingCopyBehaviourCallback;
|
||||||
import org.alfresco.repo.policy.BehaviourFilter;
|
import org.alfresco.repo.policy.BehaviourFilter;
|
||||||
import org.alfresco.repo.policy.JavaBehaviour;
|
import org.alfresco.repo.policy.JavaBehaviour;
|
||||||
@@ -134,6 +137,12 @@ public class RecordCopyBehaviours implements RecordsManagementModel
|
|||||||
QName.createQName(NamespaceService.ALFRESCO_URI, "onMoveNode"),
|
QName.createQName(NamespaceService.ALFRESCO_URI, "onMoveNode"),
|
||||||
RecordsManagementModel.TYPE_RECORD_FOLDER,
|
RecordsManagementModel.TYPE_RECORD_FOLDER,
|
||||||
new JavaBehaviour(this, "onMoveRecordFolderNode", NotificationFrequency.FIRST_EVENT));
|
new JavaBehaviour(this, "onMoveRecordFolderNode", NotificationFrequency.FIRST_EVENT));
|
||||||
|
|
||||||
|
//Copy Behaviour
|
||||||
|
this.policyComponent.bindClassBehaviour(
|
||||||
|
QName.createQName(NamespaceService.ALFRESCO_URI, "getCopyCallback"),
|
||||||
|
RecordsManagementModel.TYPE_RECORD_FOLDER,
|
||||||
|
new JavaBehaviour(this, "onCopyRecordFolderNode"));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -214,6 +223,27 @@ public class RecordCopyBehaviours implements RecordsManagementModel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CopyBehaviourCallback onCopyRecordFolderNode(final QName classRef, final CopyDetails copyDetails)
|
||||||
|
{
|
||||||
|
return new DefaultCopyBehaviourCallback()
|
||||||
|
{
|
||||||
|
final NodeService nodeService = rmServiceRegistry.getNodeService();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If the targets parent is a Record Folder -- Do Not Allow Copy
|
||||||
|
*
|
||||||
|
* @param classQName
|
||||||
|
* @param copyDetails
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean getMustCopy(QName classQName, CopyDetails copyDetails)
|
||||||
|
{
|
||||||
|
return nodeService.getType(copyDetails.getTargetParentNodeRef()).equals(TYPE_RECORD_FOLDER) ? false : true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes unwanted aspects
|
* Removes unwanted aspects
|
||||||
*
|
*
|
||||||
|
Reference in New Issue
Block a user