mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
Merging BRANCHES/DEV/CMIS_10 to HEAD (phase 2 - currently up-to-date with branch):
18717: SAIL-166: Refactor CMIS to use shared services and resolve objectIds and error codes consistently 18731: SAIL-169: CMIS REST versioning compliance 18732: Fix failing change log test. 18768: Add displayName and queryName attributes to rendered properties (in CMIS AtomPub binding). 18775: Fix exception reporting when retrieving items that do not exist (in CMIS AtomPub binding). 18784: Fix CMIS REST change logging 18785: SAIL-174: CMIS Relationship lookup by association ID 18812: SAIL-183: Support orderBy argument for getChildren and getCheckedOutDocs in CMIS REST and Web Service bindings 18823: CMIS WS Bindings were moved to 1.0 cd07 schema. 18838: Update to latest Chemistry TCK. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18847 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) 2005-2007 Alfresco Software Limited.
|
||||
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
@@ -18,7 +18,7 @@
|
||||
* As a special exception to the terms and conditions of version 2.0 of
|
||||
* the GPL, you may redistribute this Program in connection with Free/Libre
|
||||
* and Open Source Software ("FLOSS") applications as described in Alfresco's
|
||||
* FLOSS exception. You should have recieved a copy of the text describing
|
||||
* FLOSS exception. You should have received a copy of the text describing
|
||||
* the FLOSS exception, and it is also available here:
|
||||
* http://www.alfresco.com/legal/licensing"
|
||||
*/
|
||||
@@ -29,6 +29,7 @@ import java.util.Collection;
|
||||
|
||||
import org.alfresco.cmis.CMISDictionaryModel;
|
||||
import org.alfresco.cmis.CMISQueryException;
|
||||
import org.alfresco.cmis.CMISServices;
|
||||
import org.alfresco.model.ContentModel;
|
||||
import org.alfresco.repo.search.impl.lucene.AnalysisMode;
|
||||
import org.alfresco.repo.search.impl.lucene.LuceneFunction;
|
||||
@@ -51,8 +52,9 @@ import org.apache.lucene.search.BooleanClause.Occur;
|
||||
* Get the CMIS object id property.
|
||||
*
|
||||
* @author andyh
|
||||
* @author dward
|
||||
*/
|
||||
public class ObjectIdProperty extends AbstractProperty
|
||||
public class ObjectIdProperty extends AbstractVersioningProperty
|
||||
{
|
||||
/**
|
||||
* Construct
|
||||
@@ -70,24 +72,17 @@ public class ObjectIdProperty extends AbstractProperty
|
||||
*/
|
||||
public Serializable getValue(NodeRef nodeRef)
|
||||
{
|
||||
if (!getServiceRegistry().getNodeService().hasAspect(nodeRef, ContentModel.ASPECT_WORKING_COPY))
|
||||
NodeRef versionSeries;
|
||||
if (isWorkingCopy(nodeRef) || (versionSeries = getVersionSeries(nodeRef)).equals(nodeRef))
|
||||
{
|
||||
if (getServiceRegistry().getNodeService().hasAspect(nodeRef, ContentModel.ASPECT_VERSIONABLE))
|
||||
{
|
||||
Serializable value = getServiceRegistry().getNodeService().getProperty(nodeRef, ContentModel.PROP_VERSION_LABEL);
|
||||
if (value != null)
|
||||
{
|
||||
String versionLabel = DefaultTypeConverter.INSTANCE.convert(String.class, value);
|
||||
StringBuilder builder = new StringBuilder(128);
|
||||
builder.append(nodeRef.toString());
|
||||
builder.append(";");
|
||||
builder.append(versionLabel);
|
||||
return builder.toString();
|
||||
}
|
||||
}
|
||||
return nodeRef.toString();
|
||||
}
|
||||
else
|
||||
{
|
||||
return new StringBuilder(1024).append(versionSeries.toString()).append(';').append(
|
||||
getServiceRegistry().getNodeService().getProperty(nodeRef, ContentModel.PROP_VERSION_LABEL))
|
||||
.toString();
|
||||
}
|
||||
|
||||
return nodeRef.toString();
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -96,8 +91,7 @@ public class ObjectIdProperty extends AbstractProperty
|
||||
*/
|
||||
public Serializable getValue(AssociationRef assocRef)
|
||||
{
|
||||
// TODO: determine appropriate id for associations
|
||||
return assocRef.getSourceRef().toString();
|
||||
return CMISServices.ASSOC_ID_PREFIX + assocRef.getId();
|
||||
}
|
||||
|
||||
public String getLuceneFieldName()
|
||||
|
Reference in New Issue
Block a user