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;
28 import java.util.StringTokenizer;
30 import org.collectionspace.services.AcquisitionListItemJAXBSchema;
31 import org.collectionspace.services.common.document.DocumentWrapper;
32 import org.collectionspace.services.acquisition.AcquisitionsCommon;
33 import org.collectionspace.services.acquisition.AcquisitionsCommonList;
34 import org.collectionspace.services.acquisition.AcquisitionsCommonList.AcquisitionListItem;
35 import org.collectionspace.services.acquisition.AcquisitionSourceList;
36 import org.collectionspace.services.acquisition.OwnerList;
37 import org.collectionspace.services.common.document.DocumentHandler.Action;
38 import org.collectionspace.services.jaxb.AbstractCommonList;
39 import org.collectionspace.services.nuxeo.client.java.RemoteDocumentModelHandlerImpl;
40 import org.collectionspace.services.nuxeo.util.NuxeoUtils;
41 import org.nuxeo.ecm.core.api.DocumentModel;
42 import org.nuxeo.ecm.core.api.DocumentModelList;
43 import org.slf4j.Logger;
44 import org.slf4j.LoggerFactory;
47 * AcquisitionDocumentModelHandler
49 * $LastChangedRevision: $
52 public class AcquisitionDocumentModelHandler
53 extends RemoteDocumentModelHandlerImpl<AcquisitionsCommon, AcquisitionsCommonList> {
55 private final Logger logger = LoggerFactory.getLogger(AcquisitionDocumentModelHandler.class);
57 * acquisition is used to stash JAXB object to use when handle is called
58 * for Action.CREATE, Action.UPDATE or Action.GET
60 private AcquisitionsCommon acquisition;
62 * acquisitionList is stashed when handle is called
65 private AcquisitionsCommonList acquisitionList;
69 * getCommonPart get associated acquisition
73 public AcquisitionsCommon getCommonPart() {
78 * setCommonPart set associated acquisition
82 public void setCommonPart(AcquisitionsCommon acquisition) {
83 this.acquisition = acquisition;
87 * getAcquisitionList get associated acquisition (for index/GET_ALL)
91 public AcquisitionsCommonList getCommonPartList() {
92 return acquisitionList;
96 public void setCommonPartList(AcquisitionsCommonList acquisitionList) {
97 this.acquisitionList = acquisitionList;
101 public AcquisitionsCommon extractCommonPart(DocumentWrapper<DocumentModel> wrapDoc)
103 throw new UnsupportedOperationException();
107 public void fillCommonPart(AcquisitionsCommon acquisitionObject, DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
108 throw new UnsupportedOperationException();
112 public AcquisitionsCommonList extractCommonPartList(DocumentWrapper<DocumentModelList> wrapDoc) throws Exception {
113 AcquisitionsCommonList coList = this.extractPagingInfo(new AcquisitionsCommonList(), wrapDoc);
114 AbstractCommonList commonList = (AbstractCommonList) coList;
115 commonList.setFieldsReturned("acquisitionReferenceNumber|acquisitionSources|owners|uri|csid");
116 List<AcquisitionsCommonList.AcquisitionListItem> list = coList.getAcquisitionListItem();
117 Iterator<DocumentModel> iter = wrapDoc.getWrappedObject().iterator();
118 String label = getServiceContext().getCommonPartLabel();
119 while (iter.hasNext()) {
120 DocumentModel docModel = iter.next();
121 AcquisitionListItem listItem = new AcquisitionListItem();
122 listItem.setAcquisitionReferenceNumber((String) docModel.getProperty(label,
123 AcquisitionListItemJAXBSchema.ACQUISITION_REFERENCE_NUMBER));
125 // docModel.getProperty returns an ArrayList here.
126 List<String> acquisitionSources =
127 (List<String>) docModel.getProperty(label,
128 AcquisitionListItemJAXBSchema.ACQUISITION_SOURCES);
129 AcquisitionSourceList acquisitionSourceList = new AcquisitionSourceList();
130 for (String acquisitionSource : acquisitionSources) {
131 acquisitionSourceList.getAcquisitionSource().add(acquisitionSource);
133 listItem.setAcquisitionSources(acquisitionSourceList);
136 List<String> owners =
137 (List<String>) docModel.getProperty(label,
138 AcquisitionListItemJAXBSchema.OWNERS);
139 OwnerList ownerList = new OwnerList();
140 for (String owner : owners) {
141 acquisitionSourceList.getAcquisitionSource().add(owner);
143 listItem.setOwners(ownerList);
145 //need fully qualified context for URI
146 String id = NuxeoUtils.extractId(docModel.getPathAsString());
147 listItem.setUri(getServiceContextPath() + id);
148 listItem.setCsid(id);
156 public void fillAllParts(DocumentWrapper<DocumentModel> wrapDoc, Action action) throws Exception {
158 super.fillAllParts(wrapDoc, action);
159 fillDublinCoreObject(wrapDoc); //dublincore might not be needed in future
162 private void fillDublinCoreObject(DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
163 DocumentModel docModel = wrapDoc.getWrappedObject();
164 //FIXME property setter should be dynamically set using schema inspection
165 //so it does not require hard coding
166 // a default title for the Dublin Core schema
167 docModel.setPropertyValue("dublincore:title", AcquisitionConstants.NUXEO_DC_TITLE);
172 * getQProperty converts the given property to qualified schema property
177 public String getQProperty(String prop) {
178 return AcquisitionConstants.NUXEO_SCHEMA_NAME + ":" + prop;
181 // The following are all private in DocumentUtils;
182 // might be moved to a common class.
183 private static String NAME_VALUE_SEPARATOR = "|";
185 private static class NameValue {
187 // default scoped constructor to remove "synthetic accessor" warning