mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
Merged API-STRIKES-BACK (5.2.0) to HEAD (5.2)
127040 jvonka: Node Associations - child & peer - exclude "sys" namespace - common code for listing - RA-745, 920, RA-921, RA-930, RA-742, RA-918, RA-919 git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@127587 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -18,10 +18,8 @@
|
||||
*/
|
||||
package org.alfresco.rest.api.nodes;
|
||||
|
||||
import org.alfresco.rest.api.model.Assoc;
|
||||
import org.alfresco.rest.api.model.AssocTarget;
|
||||
import org.alfresco.rest.api.model.Node;
|
||||
import org.alfresco.rest.api.model.UserInfo;
|
||||
import org.alfresco.rest.framework.WebApiDescription;
|
||||
import org.alfresco.rest.framework.core.exceptions.ConstraintViolatedException;
|
||||
import org.alfresco.rest.framework.core.exceptions.EntityNotFoundException;
|
||||
@@ -29,7 +27,6 @@ import org.alfresco.rest.framework.core.exceptions.InvalidArgumentException;
|
||||
import org.alfresco.rest.framework.resource.RelationshipResource;
|
||||
import org.alfresco.rest.framework.resource.actions.interfaces.RelationshipResourceAction;
|
||||
import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo;
|
||||
import org.alfresco.rest.framework.resource.parameters.Paging;
|
||||
import org.alfresco.rest.framework.resource.parameters.Parameters;
|
||||
import org.alfresco.service.cmr.repository.AssociationExistsException;
|
||||
import org.alfresco.service.cmr.repository.AssociationRef;
|
||||
@@ -40,9 +37,7 @@ import org.alfresco.service.namespace.QNamePattern;
|
||||
import org.alfresco.service.namespace.RegexQNamePattern;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* Node Targets
|
||||
@@ -72,32 +67,7 @@ public class NodeTargetsRelation extends AbstractNodeRelation implements
|
||||
|
||||
List<AssociationRef> assocRefs = nodeService.getTargetAssocs(sourceNodeRef, assocTypeQNameParam);
|
||||
|
||||
Map<QName, String> qnameMap = new HashMap<>(3);
|
||||
|
||||
Map<String, UserInfo> mapUserInfo = new HashMap<>(10);
|
||||
|
||||
List<String> includeParam = parameters.getInclude();
|
||||
|
||||
List<Node> collection = new ArrayList<>(assocRefs.size());
|
||||
for (AssociationRef assocRef : assocRefs)
|
||||
{
|
||||
// minimal info by default (unless "include"d otherwise)
|
||||
Node node = nodes.getFolderOrDocument(assocRef.getTargetRef(), null, null, includeParam, mapUserInfo);
|
||||
|
||||
QName assocTypeQName = assocRef.getTypeQName();
|
||||
String assocType = qnameMap.get(assocTypeQName);
|
||||
if (assocType == null)
|
||||
{
|
||||
assocType = assocTypeQName.toPrefixString(namespaceService);
|
||||
qnameMap.put(assocTypeQName, assocType);
|
||||
}
|
||||
node.setAssociation(new Assoc(assocType));
|
||||
|
||||
collection.add(node);
|
||||
}
|
||||
|
||||
Paging paging = parameters.getPaging();
|
||||
return CollectionWithPagingInfo.asPaged(paging, collection, false, collection.size());
|
||||
return listNodePeerAssocs(assocRefs, parameters, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -143,7 +113,7 @@ public class NodeTargetsRelation extends AbstractNodeRelation implements
|
||||
NodeRef tgtNodeRef = nodes.validateNode(targetNodeId);
|
||||
|
||||
String assocTypeStr = parameters.getParameter(PARAM_ASSOC_TYPE);
|
||||
QNamePattern assocTypeQName = getAssocType(assocTypeStr, false, true);
|
||||
QNamePattern assocTypeQName = getAssocType(assocTypeStr, false);
|
||||
|
||||
if (assocTypeQName == null)
|
||||
{
|
||||
|
Reference in New Issue
Block a user