mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
RM-1362: When a record folder is transferred the records should not have the review or edit review date actions
* including unit tests for the updated transfer evaluator git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/HEAD@65499 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) 2005-2011 Alfresco Software Limited.
|
||||
* Copyright (C) 2005-2014 Alfresco Software Limited.
|
||||
*
|
||||
* This file is part of Alfresco
|
||||
*
|
||||
@@ -27,29 +27,73 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
||||
import org.alfresco.service.namespace.RegexQNamePattern;
|
||||
|
||||
/**
|
||||
* Evaluates whether the node in question is transferring is either a transfer or accession.
|
||||
*
|
||||
* @author Roy Wetherall
|
||||
*/
|
||||
public class TransferEvaluator extends BaseEvaluator
|
||||
{
|
||||
/** indicates whether we are looking for accessions or transfers */
|
||||
private boolean transferAccessionIndicator = false;
|
||||
|
||||
/**
|
||||
* @param transferAccessionIndicator true if accession, false otherwise
|
||||
*/
|
||||
public void setTransferAccessionIndicator(boolean transferAccessionIndicator)
|
||||
{
|
||||
this.transferAccessionIndicator = transferAccessionIndicator;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.alfresco.module.org_alfresco_module_rm.jscript.app.BaseEvaluator#evaluateImpl(org.alfresco.service.cmr.repository.NodeRef)
|
||||
*/
|
||||
@Override
|
||||
protected boolean evaluateImpl(NodeRef nodeRef)
|
||||
{
|
||||
boolean result = false;
|
||||
|
||||
NodeRef transfer = getTransferNodeRef(nodeRef);
|
||||
if (transfer != null)
|
||||
{
|
||||
boolean actual = ((Boolean)nodeService.getProperty(transfer, RecordsManagementModel.PROP_TRANSFER_ACCESSION_INDICATOR)).booleanValue();
|
||||
result = (actual == transferAccessionIndicator);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper method to get the transfer node reference.
|
||||
* <p>
|
||||
* Takes into account records in tranferred record folders.
|
||||
*
|
||||
* @param nodeRef node reference
|
||||
* @return {@link NodeRef} transfer node
|
||||
*/
|
||||
private NodeRef getTransferNodeRef(NodeRef nodeRef)
|
||||
{
|
||||
NodeRef result = null;
|
||||
|
||||
List<ChildAssociationRef> parents = nodeService.getParentAssocs(nodeRef, RecordsManagementModel.ASSOC_TRANSFERRED, RegexQNamePattern.MATCH_ALL);
|
||||
if (parents.size() == 1)
|
||||
{
|
||||
boolean actual = ((Boolean)nodeService.getProperty(parents.get(0).getParentRef(), RecordsManagementModel.PROP_TRANSFER_ACCESSION_INDICATOR)).booleanValue();
|
||||
return (actual == transferAccessionIndicator);
|
||||
result = parents.get(0).getParentRef();
|
||||
}
|
||||
else
|
||||
{
|
||||
return false;
|
||||
if (recordService.isRecord(nodeRef))
|
||||
{
|
||||
for (NodeRef recordFolder : recordFolderService.getRecordFolders(nodeRef))
|
||||
{
|
||||
result = getTransferNodeRef(recordFolder);
|
||||
if (result != null)
|
||||
{
|
||||
break;
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
@@ -185,7 +185,15 @@ public class TransferServiceImpl extends ServiceBaseImpl implements TransferServ
|
||||
setPDFIndicationFlag(transferNodeRef, nodeRef);
|
||||
|
||||
// Set the transferring indicator aspect
|
||||
nodeService.addAspect(nodeRef, ASPECT_TRANSFERRING, null);
|
||||
nodeService.addAspect(nodeRef, ASPECT_TRANSFERRING, null);
|
||||
if (isRecordFolder(nodeRef) == true)
|
||||
{
|
||||
// add the transferring indicator aspect to all the child records
|
||||
for (NodeRef record : recordService.getRecords(nodeRef))
|
||||
{
|
||||
nodeService.addAspect(record, ASPECT_TRANSFERRING, null);
|
||||
}
|
||||
}
|
||||
|
||||
return transferNodeRef;
|
||||
}
|
||||
|
Reference in New Issue
Block a user