2 * This document is a part of the source code and related artifacts
3 * for CollectionSpace, an open source collections management system
4 * for museums and related institutions:
6 * http://www.collectionspace.org
7 * http://wiki.collectionspace.org
9 * Copyright 2009 University of California at Berkeley
11 * Licensed under the Educational Community License (ECL), Version 2.0.
12 * You may not use this file except in compliance with this License.
14 * You may obtain a copy of the ECL 2.0 License at
16 * https://source.collectionspace.org/collection-space/LICENSE.txt
18 * Unless required by applicable law or agreed to in writing, software
19 * distributed under the License is distributed on an "AS IS" BASIS,
20 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21 * See the License for the specific language governing permissions and
22 * limitations under the License.
24 package org.collectionspace.services.acquisition.nuxeo;
26 import java.util.Iterator;
27 import java.util.List;
29 import org.collectionspace.services.AcquisitionJAXBSchema;
30 import org.collectionspace.services.common.document.DocumentWrapper;
31 import org.collectionspace.services.acquisition.AcquisitionsCommon;
32 import org.collectionspace.services.acquisition.AcquisitionsCommonList;
33 import org.collectionspace.services.acquisition.AcquisitionsCommonList.AcquisitionListItem;
35 import org.collectionspace.services.common.document.DocumentHandler.Action;
36 import org.collectionspace.services.nuxeo.client.java.RemoteDocumentModelHandler;
37 import org.collectionspace.services.nuxeo.util.NuxeoUtils;
38 import org.nuxeo.ecm.core.api.DocumentModel;
39 import org.nuxeo.ecm.core.api.DocumentModelList;
40 import org.slf4j.Logger;
41 import org.slf4j.LoggerFactory;
44 * AcquisitionDocumentModelHandler
46 * $LastChangedRevision: $
49 public class AcquisitionDocumentModelHandler
50 extends RemoteDocumentModelHandler<AcquisitionsCommon, AcquisitionsCommonList> {
52 private final Logger logger = LoggerFactory.getLogger(AcquisitionDocumentModelHandler.class);
54 * acquisition is used to stash JAXB object to use when handle is called
55 * for Action.CREATE, Action.UPDATE or Action.GET
57 private AcquisitionsCommon acquisition;
59 * acquisitionList is stashed when handle is called
62 private AcquisitionsCommonList acquisitionList;
65 public void prepare(Action action) throws Exception {
66 //no specific action needed
70 * getCommonPart get associated acquisition
74 public AcquisitionsCommon getCommonPart() {
79 * setCommonPart set associated acquisition
83 public void setCommonPart(AcquisitionsCommon acquisition) {
84 this.acquisition = acquisition;
88 * getAcquisitionList get associated acquisition (for index/GET_ALL)
92 public AcquisitionsCommonList getCommonPartList() {
93 return acquisitionList;
97 public void setCommonPartList(AcquisitionsCommonList acquisitionList) {
98 this.acquisitionList = acquisitionList;
102 public AcquisitionsCommon extractCommonPart(DocumentWrapper<DocumentModel> wrapDoc)
104 throw new UnsupportedOperationException();
108 public void fillCommonPart(AcquisitionsCommon acquisitionObject, DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
109 throw new UnsupportedOperationException();
113 public AcquisitionsCommonList extractCommonPartList(DocumentWrapper<DocumentModelList> wrapDoc) throws Exception {
114 DocumentModelList docList = wrapDoc.getWrappedObject();
115 AcquisitionsCommonList coList = new AcquisitionsCommonList();
116 List<AcquisitionsCommonList.AcquisitionListItem> list = coList.getAcquisitionListItem();
118 //FIXME: iterating over a long list of documents is not a long term
119 //strategy...need to change to more efficient iterating in future
120 Iterator<DocumentModel> iter = docList.iterator();
121 while (iter.hasNext()) {
122 DocumentModel docModel = iter.next();
123 AcquisitionListItem listItem = new AcquisitionListItem();
124 listItem.setAccessionDate((String) docModel.getProperty(getServiceContext().getCommonPartLabel(),
125 AcquisitionJAXBSchema.ACCESSIONDATE));
126 //need fully qualified context for URI
127 String id = NuxeoUtils.extractId(docModel.getPathAsString());
128 listItem.setUri(getServiceContextPath() + id);
129 listItem.setCsid(id);
137 public void fillAllParts(DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
139 super.fillAllParts(wrapDoc);
140 fillDublinCoreObject(wrapDoc); //dublincore might not be needed in future
143 private void fillDublinCoreObject(DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
144 DocumentModel docModel = wrapDoc.getWrappedObject();
145 //FIXME property setter should be dynamically set using schema inspection
146 //so it does not require hard coding
147 // a default title for the Dublin Core schema
148 docModel.setPropertyValue("dublincore:title", AcquisitionConstants.NUXEO_DC_TITLE);
153 * getQProperty converts the given property to qualified schema property
158 public String getQProperty(String prop) {
159 return AcquisitionConstants.NUXEO_SCHEMA_NAME + ":" + prop;