mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
RM Performance Improvements:
* focus on in-place scenarios with large numbers of DM users and large numbers of in-place records (based on issue informally reported by partner) * improve performance of dynamic authorities used for in-place security evaluation (L1 transaction cache and more preformant authority look up) * remove unwanted queries in tree (N+1 for every node) .. killed it for large file plans * L1 transaction cache for capability condition evaluation .. these are called a LOT so removes some of the bottle necks when evaluating the permissions of a large sets of nodes * extend helper system test used to load up fileplan and now also create in-place records * unit and integration tests run .. sanity testing done via the UI * overall performance of the display of 1000 in-place records in the file plan down from minutes to a few seconds! git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/HEAD@75186 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -20,7 +20,7 @@ function getTreenode()
|
|||||||
"{http://www.alfresco.org/model/recordsmanagement/1.0}unfiledRecordContainer":true
|
"{http://www.alfresco.org/model/recordsmanagement/1.0}unfiledRecordContainer":true
|
||||||
},
|
},
|
||||||
skipPermissionCheck = args["perms"] == "false",
|
skipPermissionCheck = args["perms"] == "false",
|
||||||
evalChildFolders = args["children"] !== "false",
|
evalChildFolders = false,
|
||||||
item, rmNode, capabilities, cap;
|
item, rmNode, capabilities, cap;
|
||||||
|
|
||||||
// Use helper function to get the arguments
|
// Use helper function to get the arguments
|
||||||
|
@@ -38,6 +38,7 @@ import org.apache.commons.logging.Log;
|
|||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
import org.springframework.context.ApplicationContextAware;
|
import org.springframework.context.ApplicationContextAware;
|
||||||
|
import org.springframework.extensions.webscripts.GUID;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -18,12 +18,17 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.capability.declarative;
|
package org.alfresco.module.org_alfresco_module_rm.capability.declarative;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.disposition.DispositionService;
|
import org.alfresco.module.org_alfresco_module_rm.disposition.DispositionService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.fileplan.FilePlanService;
|
import org.alfresco.module.org_alfresco_module_rm.fileplan.FilePlanService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.freeze.FreezeService;
|
import org.alfresco.module.org_alfresco_module_rm.freeze.FreezeService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.record.RecordService;
|
import org.alfresco.module.org_alfresco_module_rm.record.RecordService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.recordfolder.RecordFolderService;
|
import org.alfresco.module.org_alfresco_module_rm.recordfolder.RecordFolderService;
|
||||||
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||||
|
import org.alfresco.repo.transaction.TransactionalResourceHelper;
|
||||||
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.repository.NodeService;
|
import org.alfresco.service.cmr.repository.NodeService;
|
||||||
import org.alfresco.service.cmr.security.PermissionService;
|
import org.alfresco.service.cmr.security.PermissionService;
|
||||||
import org.springframework.beans.factory.BeanNameAware;
|
import org.springframework.beans.factory.BeanNameAware;
|
||||||
@@ -37,6 +42,9 @@ public abstract class AbstractCapabilityCondition implements CapabilityCondition
|
|||||||
BeanNameAware,
|
BeanNameAware,
|
||||||
RecordsManagementModel
|
RecordsManagementModel
|
||||||
{
|
{
|
||||||
|
/** transaction cache key */
|
||||||
|
private static final String KEY_EVALUATE = "rm.transaction.evaluate";
|
||||||
|
|
||||||
/** Capability condition name */
|
/** Capability condition name */
|
||||||
protected String name;
|
protected String name;
|
||||||
|
|
||||||
@@ -113,6 +121,32 @@ public abstract class AbstractCapabilityCondition implements CapabilityCondition
|
|||||||
{
|
{
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean evaluate(NodeRef nodeRef)
|
||||||
|
{
|
||||||
|
boolean result = false;
|
||||||
|
|
||||||
|
// check transaction cache
|
||||||
|
Map<String, Boolean> map = TransactionalResourceHelper.getMap(KEY_EVALUATE);
|
||||||
|
String key = getName() + "|" + nodeRef.toString() + "|" + AuthenticationUtil.getRunAsUser();
|
||||||
|
if (map.containsKey(key))
|
||||||
|
{
|
||||||
|
result = map.get(key);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = evaluateImpl(nodeRef);
|
||||||
|
map.put(key, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract boolean evaluateImpl(NodeRef nodeRef);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see org.springframework.beans.factory.BeanNameAware#setBeanName(java.lang.String)
|
* @see org.springframework.beans.factory.BeanNameAware#setBeanName(java.lang.String)
|
||||||
|
@@ -20,9 +20,26 @@ package org.alfresco.module.org_alfresco_module_rm.capability.declarative;
|
|||||||
|
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Capability condition.
|
||||||
|
*
|
||||||
|
* @author Roy Wetherall
|
||||||
|
* @since 2.0
|
||||||
|
*/
|
||||||
public interface CapabilityCondition
|
public interface CapabilityCondition
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Get capability condition name
|
||||||
|
*
|
||||||
|
* @return {@link String} capability condition name
|
||||||
|
*/
|
||||||
String getName();
|
String getName();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Evaluates capability condition.
|
||||||
|
*
|
||||||
|
* @param nodeRef node reference
|
||||||
|
* @return boolean true if evaluate success, false otherwise
|
||||||
|
*/
|
||||||
boolean evaluate(NodeRef nodeRef);
|
boolean evaluate(NodeRef nodeRef);
|
||||||
}
|
}
|
@@ -42,12 +42,18 @@ public class AtLeastOneCondition extends AbstractCapabilityCondition
|
|||||||
{
|
{
|
||||||
this.conditions = conditions;
|
this.conditions = conditions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean evaluate(NodeRef nodeRef)
|
||||||
|
{
|
||||||
|
return evaluateImpl(nodeRef);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -35,7 +35,7 @@ public class ClosedCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
if (recordFolderService.isRecordFolder(nodeRef))
|
if (recordFolderService.isRecordFolder(nodeRef))
|
||||||
|
@@ -32,7 +32,7 @@ public class CutoffCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
// determine whether the item is already cutt off
|
// determine whether the item is already cutt off
|
||||||
return dispositionService.isDisposableItemCutoff(nodeRef);
|
return dispositionService.isDisposableItemCutoff(nodeRef);
|
||||||
|
@@ -28,7 +28,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
|||||||
public class DeclaredCapabilityCondition extends AbstractCapabilityCondition
|
public class DeclaredCapabilityCondition extends AbstractCapabilityCondition
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
if (FilePlanComponentKind.RECORD.equals(filePlanService.getFilePlanComponentKind(nodeRef)))
|
if (FilePlanComponentKind.RECORD.equals(filePlanService.getFilePlanComponentKind(nodeRef)))
|
||||||
|
@@ -29,7 +29,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
|||||||
public class DestroyedCapabilityCondition extends AbstractCapabilityCondition
|
public class DestroyedCapabilityCondition extends AbstractCapabilityCondition
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
return nodeService.hasAspect(nodeRef, ASPECT_GHOSTED);
|
return nodeService.hasAspect(nodeRef, ASPECT_GHOSTED);
|
||||||
}
|
}
|
||||||
|
@@ -30,7 +30,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
|||||||
public class FailCapabilityCondition extends AbstractCapabilityCondition
|
public class FailCapabilityCondition extends AbstractCapabilityCondition
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@@ -47,7 +47,7 @@ public class FileableCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
QName type = nodeService.getType(nodeRef);
|
QName type = nodeService.getType(nodeRef);
|
||||||
// TODO and not already a record?
|
// TODO and not already a record?
|
||||||
|
@@ -34,7 +34,7 @@ public class FillingCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -34,7 +34,7 @@ private boolean checkChildren = false;
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = freezeService.isFrozen(nodeRef);
|
boolean result = freezeService.isFrozen(nodeRef);
|
||||||
if (!result && checkChildren)
|
if (!result && checkChildren)
|
||||||
|
@@ -33,7 +33,7 @@ public class FrozenOrHoldCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
FilePlanComponentKind kind = filePlanService.getFilePlanComponentKind(nodeRef);
|
FilePlanComponentKind kind = filePlanService.getFilePlanComponentKind(nodeRef);
|
||||||
return (freezeService.isFrozen(nodeRef) ||
|
return (freezeService.isFrozen(nodeRef) ||
|
||||||
|
@@ -46,7 +46,7 @@ public class HasAspectCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
if (aspectName != null)
|
if (aspectName != null)
|
||||||
|
@@ -45,7 +45,7 @@ public class HasDispositionDateCapabilityCondition extends AbstractCapabilityCon
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -45,7 +45,7 @@ public class HasEventsCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -58,7 +58,7 @@ public class HoldCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -46,7 +46,7 @@ public class IsClassifiedCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -66,7 +66,7 @@ public class IsPropertySetCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
ParameterCheck.mandatory("nodeRef", nodeRef);
|
ParameterCheck.mandatory("nodeRef", nodeRef);
|
||||||
|
|
||||||
|
@@ -34,7 +34,7 @@ public class IsRecordCategoryCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
ParameterCheck.mandatory("nodeRef", nodeRef);
|
ParameterCheck.mandatory("nodeRef", nodeRef);
|
||||||
|
|
||||||
|
@@ -34,7 +34,7 @@ public class IsRecordCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
ParameterCheck.mandatory("nodeRef", nodeRef);
|
ParameterCheck.mandatory("nodeRef", nodeRef);
|
||||||
|
|
||||||
|
@@ -34,7 +34,7 @@ public class IsRecordFolderCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
ParameterCheck.mandatory("nodeRef", nodeRef);
|
ParameterCheck.mandatory("nodeRef", nodeRef);
|
||||||
|
|
||||||
|
@@ -56,7 +56,7 @@ public class IsScheduledCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -31,7 +31,7 @@ public class IsTransferAccessionCapabilityCondition extends AbstractCapabilityCo
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -48,7 +48,7 @@ public class LastDispositionActionCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
DispositionAction dispositionAction = dispositionService.getLastCompletedDispostionAction(nodeRef);
|
DispositionAction dispositionAction = dispositionService.getLastCompletedDispostionAction(nodeRef);
|
||||||
|
@@ -57,7 +57,7 @@ public class MayBeScheduledCapabilityCondition extends AbstractCapabilityConditi
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -33,7 +33,7 @@ public class RecordFiledCapabilityCondition extends AbstractCapabilityCondition
|
|||||||
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
* @see org.alfresco.module.org_alfresco_module_rm.capability.declarative.CapabilityCondition#evaluate(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
return recordService.isFiled(nodeRef);
|
return recordService.isFiled(nodeRef);
|
||||||
}
|
}
|
||||||
|
@@ -28,7 +28,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
|||||||
public class TransferredCapabilityCondition extends AbstractCapabilityCondition
|
public class TransferredCapabilityCondition extends AbstractCapabilityCondition
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
return nodeService.hasAspect(nodeRef, RecordsManagementModel.ASPECT_TRANSFERRED);
|
return nodeService.hasAspect(nodeRef, RecordsManagementModel.ASPECT_TRANSFERRED);
|
||||||
}
|
}
|
||||||
|
@@ -28,7 +28,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
|||||||
public class VitalRecordOrFolderCapabilityCondition extends AbstractCapabilityCondition
|
public class VitalRecordOrFolderCapabilityCondition extends AbstractCapabilityCondition
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(NodeRef nodeRef)
|
public boolean evaluateImpl(NodeRef nodeRef)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
|
@@ -18,15 +18,16 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.security;
|
package org.alfresco.module.org_alfresco_module_rm.security;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
||||||
import org.alfresco.repo.security.permissions.DynamicAuthority;
|
import org.alfresco.repo.security.permissions.DynamicAuthority;
|
||||||
import org.alfresco.repo.security.permissions.PermissionReference;
|
import org.alfresco.repo.security.permissions.PermissionReference;
|
||||||
|
import org.alfresco.repo.transaction.TransactionalResourceHelper;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.repository.NodeService;
|
import org.alfresco.service.cmr.repository.NodeService;
|
||||||
import org.alfresco.service.cmr.security.AuthorityService;
|
import org.alfresco.service.cmr.security.AuthorityService;
|
||||||
import org.alfresco.service.cmr.security.AuthorityType;
|
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
import org.springframework.context.ApplicationContextAware;
|
import org.springframework.context.ApplicationContextAware;
|
||||||
|
|
||||||
@@ -40,6 +41,9 @@ public abstract class ExtendedSecurityBaseDynamicAuthority implements DynamicAut
|
|||||||
RecordsManagementModel,
|
RecordsManagementModel,
|
||||||
ApplicationContextAware
|
ApplicationContextAware
|
||||||
{
|
{
|
||||||
|
/** transaction cache key */
|
||||||
|
private static final String KEY_HAS_AUTHORITY_CACHE = "rm.transaction.hasAuthority";
|
||||||
|
|
||||||
/** Authority service */
|
/** Authority service */
|
||||||
private AuthorityService authorityService;
|
private AuthorityService authorityService;
|
||||||
|
|
||||||
@@ -132,14 +136,23 @@ public abstract class ExtendedSecurityBaseDynamicAuthority implements DynamicAut
|
|||||||
}
|
}
|
||||||
else if (authority.startsWith("GROUP_"))
|
else if (authority.startsWith("GROUP_"))
|
||||||
{
|
{
|
||||||
// check group to see if the user is contained
|
Map<String, Boolean> transactionCache = TransactionalResourceHelper.getMap(KEY_HAS_AUTHORITY_CACHE);
|
||||||
Set<String> contained = getAuthorityService().getContainedAuthorities(AuthorityType.USER, authority, false);
|
String key = authority + "|" + userName;
|
||||||
if (!contained.isEmpty() &&
|
if (transactionCache.containsKey(key))
|
||||||
contained.contains(userName))
|
|
||||||
{
|
{
|
||||||
result = true;
|
result = transactionCache.get(key);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Set<String> contained = getAuthorityService().getAuthoritiesForUser(userName);
|
||||||
|
if (contained.contains(authority))
|
||||||
|
{
|
||||||
|
result = true;
|
||||||
|
transactionCache.put(key, result);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@@ -28,6 +28,7 @@ import org.alfresco.module.org_alfresco_module_rm.hold.HoldService;
|
|||||||
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
||||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||||
import org.alfresco.repo.security.authentication.AuthenticationUtil.RunAsWork;
|
import org.alfresco.repo.security.authentication.AuthenticationUtil.RunAsWork;
|
||||||
|
import org.alfresco.repo.transaction.TransactionalResourceHelper;
|
||||||
import org.alfresco.service.cmr.dictionary.DictionaryService;
|
import org.alfresco.service.cmr.dictionary.DictionaryService;
|
||||||
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
@@ -97,7 +98,7 @@ public class ServiceBaseImpl implements RecordsManagementModel, ApplicationConte
|
|||||||
|
|
||||||
return internalNodeService;
|
return internalNodeService;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the file plan component kind from the given node reference
|
* Gets the file plan component kind from the given node reference
|
||||||
*
|
*
|
||||||
@@ -107,53 +108,66 @@ public class ServiceBaseImpl implements RecordsManagementModel, ApplicationConte
|
|||||||
{
|
{
|
||||||
FilePlanComponentKind result = null;
|
FilePlanComponentKind result = null;
|
||||||
|
|
||||||
if (isFilePlanComponent(nodeRef))
|
Map<NodeRef, FilePlanComponentKind> map = TransactionalResourceHelper.getMap("rm.transaction.filePlanComponentByNodeRef");
|
||||||
|
if (map.containsKey(nodeRef))
|
||||||
{
|
{
|
||||||
result = FilePlanComponentKind.FILE_PLAN_COMPONENT;
|
result = map.get(nodeRef);
|
||||||
|
}
|
||||||
if (isFilePlan(nodeRef))
|
else
|
||||||
|
{
|
||||||
|
if (isFilePlanComponent(nodeRef))
|
||||||
{
|
{
|
||||||
result = FilePlanComponentKind.FILE_PLAN;
|
result = FilePlanComponentKind.FILE_PLAN_COMPONENT;
|
||||||
|
|
||||||
|
if (isFilePlan(nodeRef))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.FILE_PLAN;
|
||||||
|
}
|
||||||
|
else if (isRecordCategory(nodeRef))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.RECORD_CATEGORY;
|
||||||
|
}
|
||||||
|
else if (isRecordFolder(nodeRef))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.RECORD_FOLDER;
|
||||||
|
}
|
||||||
|
else if (isRecord(nodeRef))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.RECORD;
|
||||||
|
}
|
||||||
|
else if (instanceOf(nodeRef, TYPE_HOLD_CONTAINER))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.HOLD_CONTAINER;
|
||||||
|
}
|
||||||
|
else if (isHold(nodeRef))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.HOLD;
|
||||||
|
}
|
||||||
|
else if (instanceOf(nodeRef, TYPE_TRANSFER_CONTAINER))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.TRANSFER_CONTAINER;
|
||||||
|
}
|
||||||
|
else if (isTransfer(nodeRef))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.TRANSFER;
|
||||||
|
}
|
||||||
|
else if (instanceOf(nodeRef, TYPE_DISPOSITION_SCHEDULE) || instanceOf(nodeRef, TYPE_DISPOSITION_ACTION_DEFINITION))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.DISPOSITION_SCHEDULE;
|
||||||
|
}
|
||||||
|
else if (instanceOf(nodeRef, TYPE_UNFILED_RECORD_CONTAINER))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.UNFILED_RECORD_CONTAINER;
|
||||||
|
}
|
||||||
|
else if (instanceOf(nodeRef, TYPE_UNFILED_RECORD_FOLDER))
|
||||||
|
{
|
||||||
|
result = FilePlanComponentKind.UNFILED_RECORD_FOLDER;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (isRecordCategory(nodeRef))
|
|
||||||
|
if (result != null)
|
||||||
{
|
{
|
||||||
result = FilePlanComponentKind.RECORD_CATEGORY;
|
map.put(nodeRef, result);
|
||||||
}
|
|
||||||
else if (isRecordFolder(nodeRef))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.RECORD_FOLDER;
|
|
||||||
}
|
|
||||||
else if (isRecord(nodeRef))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.RECORD;
|
|
||||||
}
|
|
||||||
else if (instanceOf(nodeRef, TYPE_HOLD_CONTAINER))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.HOLD_CONTAINER;
|
|
||||||
}
|
|
||||||
else if (isHold(nodeRef))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.HOLD;
|
|
||||||
}
|
|
||||||
else if (instanceOf(nodeRef, TYPE_TRANSFER_CONTAINER))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.TRANSFER_CONTAINER;
|
|
||||||
}
|
|
||||||
else if (isTransfer(nodeRef))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.TRANSFER;
|
|
||||||
}
|
|
||||||
else if (instanceOf(nodeRef, TYPE_DISPOSITION_SCHEDULE) || instanceOf(nodeRef, TYPE_DISPOSITION_ACTION_DEFINITION))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.DISPOSITION_SCHEDULE;
|
|
||||||
}
|
|
||||||
else if (instanceOf(nodeRef, TYPE_UNFILED_RECORD_CONTAINER))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.UNFILED_RECORD_CONTAINER;
|
|
||||||
}
|
|
||||||
else if (instanceOf(nodeRef, TYPE_UNFILED_RECORD_FOLDER))
|
|
||||||
{
|
|
||||||
result = FilePlanComponentKind.UNFILED_RECORD_FOLDER;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -415,11 +415,15 @@ public class MoveRecordFolderTest extends BaseRMTestCase
|
|||||||
// cutoff folder
|
// cutoff folder
|
||||||
rmActionService.executeRecordsManagementAction(testFolder, CutOffAction.NAME);
|
rmActionService.executeRecordsManagementAction(testFolder, CutOffAction.NAME);
|
||||||
|
|
||||||
|
return testFolder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void test(NodeRef testFolder) throws Exception
|
||||||
|
{
|
||||||
// take a look at the move capability
|
// take a look at the move capability
|
||||||
Capability moveCapability = capabilityService.getCapability("Move");
|
Capability moveCapability = capabilityService.getCapability("Move");
|
||||||
assertEquals(AccessDecisionVoter.ACCESS_DENIED, moveCapability.evaluate(testFolder, destination));
|
assertEquals(AccessDecisionVoter.ACCESS_DENIED, moveCapability.evaluate(testFolder, destination));
|
||||||
|
|
||||||
return testFolder;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@@ -55,7 +55,10 @@ public class FileReportActionTest extends BaseRMTestCase
|
|||||||
{
|
{
|
||||||
// create record folder
|
// create record folder
|
||||||
final NodeRef recordFolder = recordFolderService.createRecordFolder(rmContainer, GUID.generate());
|
final NodeRef recordFolder = recordFolderService.createRecordFolder(rmContainer, GUID.generate());
|
||||||
|
|
||||||
|
// close the record folder
|
||||||
|
recordFolderService.closeRecordFolder(recordFolder);
|
||||||
|
|
||||||
// create hold
|
// create hold
|
||||||
final NodeRef hold = holdService.createHold(filePlan, "holdName", "holdReason", "holdDescription");
|
final NodeRef hold = holdService.createHold(filePlan, "holdName", "holdReason", "holdDescription");
|
||||||
|
|
||||||
@@ -63,10 +66,7 @@ public class FileReportActionTest extends BaseRMTestCase
|
|||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void run() throws Exception
|
public void run() throws Exception
|
||||||
{
|
{
|
||||||
// close the record folder
|
|
||||||
recordFolderService.closeRecordFolder(recordFolder);
|
|
||||||
|
|
||||||
// execute action
|
// execute action
|
||||||
executeAction(mimeType, recordFolder, hold);
|
executeAction(mimeType, recordFolder, hold);
|
||||||
}
|
}
|
||||||
@@ -77,14 +77,17 @@ public class FileReportActionTest extends BaseRMTestCase
|
|||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
// reopen the record folder
|
// reopen the record folder
|
||||||
nodeService.setProperty(recordFolder, PROP_IS_CLOSED, false);
|
rmActionService.executeRecordsManagementAction(recordFolder, "openRecordFolder");
|
||||||
|
|
||||||
// execute action
|
|
||||||
executeAction(mimeType, recordFolder, hold);
|
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, ADMIN_USER);
|
|
||||||
|
@Override
|
||||||
|
public void test(Void result) throws Exception
|
||||||
|
{
|
||||||
|
// execute action
|
||||||
|
executeAction(mimeType, recordFolder, hold);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void executeAction(String mimeType, NodeRef recordFolder, NodeRef hold)
|
private void executeAction(String mimeType, NodeRef recordFolder, NodeRef hold)
|
||||||
|
@@ -7,6 +7,7 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.alfresco.model.ContentModel;
|
import org.alfresco.model.ContentModel;
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.action.RecordsManagementActionService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.fileplan.FilePlanService;
|
import org.alfresco.module.org_alfresco_module_rm.fileplan.FilePlanService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.record.RecordService;
|
import org.alfresco.module.org_alfresco_module_rm.record.RecordService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.recordfolder.RecordFolderService;
|
import org.alfresco.module.org_alfresco_module_rm.recordfolder.RecordFolderService;
|
||||||
@@ -15,11 +16,15 @@ import org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils;
|
|||||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||||
import org.alfresco.repo.security.authentication.AuthenticationUtil.RunAsWork;
|
import org.alfresco.repo.security.authentication.AuthenticationUtil.RunAsWork;
|
||||||
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
||||||
|
import org.alfresco.service.cmr.model.FileFolderService;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.security.AuthorityService;
|
import org.alfresco.service.cmr.security.AuthorityService;
|
||||||
import org.alfresco.service.cmr.security.AuthorityType;
|
import org.alfresco.service.cmr.security.AuthorityType;
|
||||||
import org.alfresco.service.cmr.security.MutableAuthenticationService;
|
import org.alfresco.service.cmr.security.MutableAuthenticationService;
|
||||||
import org.alfresco.service.cmr.security.PersonService;
|
import org.alfresco.service.cmr.security.PersonService;
|
||||||
|
import org.alfresco.service.cmr.site.SiteInfo;
|
||||||
|
import org.alfresco.service.cmr.site.SiteRole;
|
||||||
|
import org.alfresco.service.cmr.site.SiteService;
|
||||||
import org.alfresco.service.namespace.QName;
|
import org.alfresco.service.namespace.QName;
|
||||||
import org.alfresco.service.transaction.TransactionService;
|
import org.alfresco.service.transaction.TransactionService;
|
||||||
import org.alfresco.util.ApplicationContextHelper;
|
import org.alfresco.util.ApplicationContextHelper;
|
||||||
@@ -40,6 +45,8 @@ public class DataLoadSystemTest
|
|||||||
protected MutableAuthenticationService authenticationService;
|
protected MutableAuthenticationService authenticationService;
|
||||||
protected PersonService personService;
|
protected PersonService personService;
|
||||||
protected FilePlanRoleService filePlanRoleService;
|
protected FilePlanRoleService filePlanRoleService;
|
||||||
|
protected SiteService siteService;
|
||||||
|
protected FileFolderService fileFolderService;
|
||||||
|
|
||||||
/** config locations */
|
/** config locations */
|
||||||
protected String[] getConfigLocations()
|
protected String[] getConfigLocations()
|
||||||
@@ -63,6 +70,10 @@ public class DataLoadSystemTest
|
|||||||
private static final int RM_GROUP_COUNT = 0;
|
private static final int RM_GROUP_COUNT = 0;
|
||||||
private static final int RM_USER_COUNT = 0;
|
private static final int RM_USER_COUNT = 0;
|
||||||
|
|
||||||
|
/** inplace sizing */
|
||||||
|
private static final int USER_COUNT = 0;
|
||||||
|
private static final int INPLACE_RECORD_COUNT = 5000;
|
||||||
|
|
||||||
/** application context */
|
/** application context */
|
||||||
private ApplicationContext applicationContext;
|
private ApplicationContext applicationContext;
|
||||||
CommonRMTestUtils utils;
|
CommonRMTestUtils utils;
|
||||||
@@ -86,13 +97,71 @@ public class DataLoadSystemTest
|
|||||||
authenticationService = (MutableAuthenticationService)applicationContext.getBean("AuthenticationService");
|
authenticationService = (MutableAuthenticationService)applicationContext.getBean("AuthenticationService");
|
||||||
personService = (PersonService)applicationContext.getBean("personService");
|
personService = (PersonService)applicationContext.getBean("personService");
|
||||||
filePlanRoleService = (FilePlanRoleService)applicationContext.getBean("filePlanRoleService");
|
filePlanRoleService = (FilePlanRoleService)applicationContext.getBean("filePlanRoleService");
|
||||||
|
siteService = (SiteService)applicationContext.getBean("siteService");
|
||||||
|
fileFolderService = (FileFolderService)applicationContext.getBean("fileFolderService");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
private void loadAllData()
|
public void loadAllData()
|
||||||
{
|
{
|
||||||
loadFilePlanData();
|
loadFilePlanData();
|
||||||
loadRMUsersAndGroups();
|
loadRMUsersAndGroups();
|
||||||
|
loadInPlace();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void loadInPlace()
|
||||||
|
{
|
||||||
|
AuthenticationUtil.runAs(new RunAsWork<Void>()
|
||||||
|
{
|
||||||
|
public Void doWork() throws Exception
|
||||||
|
{
|
||||||
|
final SiteInfo site = siteService.getSite("test");
|
||||||
|
if (site == null)
|
||||||
|
{
|
||||||
|
Assert.fail("The collab site test is not present.");
|
||||||
|
}
|
||||||
|
|
||||||
|
final NodeRef filePlan = filePlanService.getFilePlanBySiteId(FilePlanService.DEFAULT_RM_SITE_ID);
|
||||||
|
if (filePlan == null)
|
||||||
|
{
|
||||||
|
Assert.fail("The default RM site is not present.");
|
||||||
|
}
|
||||||
|
|
||||||
|
// create users and add to site
|
||||||
|
repeatInTransactionBatches(new RunAsWork<Void>()
|
||||||
|
{
|
||||||
|
public Void doWork() throws Exception
|
||||||
|
{
|
||||||
|
// create user
|
||||||
|
String userName = GUID.generate();
|
||||||
|
System.out.println("Creating user " + userName);
|
||||||
|
createPerson(userName, true);
|
||||||
|
|
||||||
|
// add to collab site
|
||||||
|
siteService.setMembership("test", userName, SiteRole.SiteCollaborator.toString());
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}, USER_COUNT);
|
||||||
|
|
||||||
|
// create content and declare as record
|
||||||
|
repeatInTransactionBatches(new RunAsWork<Void>()
|
||||||
|
{
|
||||||
|
public Void doWork() throws Exception
|
||||||
|
{
|
||||||
|
// create document
|
||||||
|
NodeRef docLib = siteService.getContainer(site.getShortName(), SiteService.DOCUMENT_LIBRARY);
|
||||||
|
NodeRef document = fileFolderService.create(docLib, GUID.generate(), ContentModel.TYPE_CONTENT).getNodeRef();
|
||||||
|
|
||||||
|
recordService.createRecord(filePlan, document);
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}, INPLACE_RECORD_COUNT);
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}, AuthenticationUtil.getAdminUserName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -94,7 +94,7 @@ public class HoldCapabilityConditionUnitTest extends BaseUnitTest
|
|||||||
doReturn(Collections.EMPTY_LIST).when(mockedHoldService).heldBy(eq(recordFolder), anyBoolean());
|
doReturn(Collections.EMPTY_LIST).when(mockedHoldService).heldBy(eq(recordFolder), anyBoolean());
|
||||||
|
|
||||||
// when
|
// when
|
||||||
boolean result = evaluator.evaluate(recordFolder);
|
boolean result = evaluator.evaluateImpl(recordFolder);
|
||||||
|
|
||||||
// then
|
// then
|
||||||
assertFalse(result);
|
assertFalse(result);
|
||||||
@@ -114,7 +114,7 @@ public class HoldCapabilityConditionUnitTest extends BaseUnitTest
|
|||||||
doReturn(AccessStatus.DENIED).when(mockedPermissionService).hasPermission(hold2, RMPermissionModel.FILING);
|
doReturn(AccessStatus.DENIED).when(mockedPermissionService).hasPermission(hold2, RMPermissionModel.FILING);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
boolean result = evaluator.evaluate(recordFolder);
|
boolean result = evaluator.evaluateImpl(recordFolder);
|
||||||
|
|
||||||
// then
|
// then
|
||||||
assertFalse(result);
|
assertFalse(result);
|
||||||
@@ -134,7 +134,7 @@ public class HoldCapabilityConditionUnitTest extends BaseUnitTest
|
|||||||
doReturn(AccessStatus.ALLOWED).when(mockedPermissionService).hasPermission(hold2, RMPermissionModel.FILING);
|
doReturn(AccessStatus.ALLOWED).when(mockedPermissionService).hasPermission(hold2, RMPermissionModel.FILING);
|
||||||
|
|
||||||
// when
|
// when
|
||||||
boolean result = evaluator.evaluate(recordFolder);
|
boolean result = evaluator.evaluateImpl(recordFolder);
|
||||||
|
|
||||||
// then
|
// then
|
||||||
assertTrue(result);
|
assertTrue(result);
|
||||||
|
@@ -31,6 +31,7 @@ import java.util.Set;
|
|||||||
|
|
||||||
import org.alfresco.model.ContentModel;
|
import org.alfresco.model.ContentModel;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.capability.RMPermissionModel;
|
import org.alfresco.module.org_alfresco_module_rm.capability.RMPermissionModel;
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.fileplan.FilePlanComponentKind;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.test.util.BaseUnitTest;
|
import org.alfresco.module.org_alfresco_module_rm.test.util.BaseUnitTest;
|
||||||
import org.alfresco.repo.security.permissions.impl.AccessPermissionImpl;
|
import org.alfresco.repo.security.permissions.impl.AccessPermissionImpl;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
@@ -128,6 +129,17 @@ public class FilePlanPermissionServiceImplUnitTest extends BaseUnitTest
|
|||||||
|
|
||||||
makeChildrenOf(holdContainer, hold);
|
makeChildrenOf(holdContainer, hold);
|
||||||
makeChildrenOf(hold, heldRecord);
|
makeChildrenOf(hold, heldRecord);
|
||||||
|
|
||||||
|
doReturn(FilePlanComponentKind.FILE_PLAN).when(filePlanPermissionService).getFilePlanComponentKind(filePlan);
|
||||||
|
doReturn(FilePlanComponentKind.RECORD_CATEGORY).when(filePlanPermissionService).getFilePlanComponentKind(rootRecordCategory);
|
||||||
|
doReturn(FilePlanComponentKind.RECORD_CATEGORY).when(filePlanPermissionService).getFilePlanComponentKind(recordCategory);
|
||||||
|
doReturn(FilePlanComponentKind.RECORD_FOLDER).when(filePlanPermissionService).getFilePlanComponentKind(newRecordFolder);
|
||||||
|
doReturn(FilePlanComponentKind.RECORD).when(filePlanPermissionService).getFilePlanComponentKind(newRecord);
|
||||||
|
doReturn(FilePlanComponentKind.UNFILED_RECORD_FOLDER).when(filePlanPermissionService).getFilePlanComponentKind(unfiledRecordFolder);
|
||||||
|
doReturn(FilePlanComponentKind.UNFILED_RECORD_CONTAINER).when(filePlanPermissionService).getFilePlanComponentKind(unfiledRecordContainer);
|
||||||
|
doReturn(FilePlanComponentKind.RECORD).when(filePlanPermissionService).getFilePlanComponentKind(unfiledRecord);
|
||||||
|
doReturn(FilePlanComponentKind.HOLD_CONTAINER).when(filePlanPermissionService).getFilePlanComponentKind(holdContainer);
|
||||||
|
doReturn(FilePlanComponentKind.HOLD).when(filePlanPermissionService).getFilePlanComponentKind(hold);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Reference in New Issue
Block a user