]> git.aero2k.de Git - tmp/jakarta-migration.git/blob
1f83eb560869dccf7f927c92e0a4e1e8b8df0708
[tmp/jakarta-migration.git] /
1 /**
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:
5
6  *  http://www.collectionspace.org
7  *  http://wiki.collectionspace.org
8
9  *  Copyright 2009 University of California at Berkeley
10
11  *  Licensed under the Educational Community License (ECL), Version 2.0.
12  *  You may not use this file except in compliance with this License.
13
14  *  You may obtain a copy of the ECL 2.0 License at
15
16  *  https://source.collectionspace.org/collection-space/LICENSE.txt
17
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.
23  */
24 package org.collectionspace.services.acquisition.nuxeo;
25
26 import java.util.Iterator;
27 import java.util.List;
28
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;
34
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;
42
43 /**
44  * AcquisitionDocumentModelHandler
45  *
46  * $LastChangedRevision: $
47  * $LastChangedDate: $
48  */
49 public class AcquisitionDocumentModelHandler
50         extends RemoteDocumentModelHandler<AcquisitionsCommon, AcquisitionsCommonList> {
51
52     private final Logger logger = LoggerFactory.getLogger(AcquisitionDocumentModelHandler.class);
53     /**
54      * acquisition is used to stash JAXB object to use when handle is called
55      * for Action.CREATE, Action.UPDATE or Action.GET
56      */
57     private AcquisitionsCommon acquisition;
58     /**
59      * acquisitionList is stashed when handle is called
60      * for ACTION.GET_ALL
61      */
62     private AcquisitionsCommonList acquisitionList;
63
64     @Override
65     public void prepare(Action action) throws Exception {
66         //no specific action needed
67     }
68
69     /**
70      * getCommonPart get associated acquisition
71      * @return
72      */
73     @Override
74     public AcquisitionsCommon getCommonPart() {
75         return acquisition;
76     }
77
78     /**
79      * setCommonPart set associated acquisition
80      * @param acquisition
81      */
82     @Override
83     public void setCommonPart(AcquisitionsCommon acquisition) {
84         this.acquisition = acquisition;
85     }
86
87     /**
88      * getAcquisitionList get associated acquisition (for index/GET_ALL)
89      * @return
90      */
91     @Override
92     public AcquisitionsCommonList getCommonPartList() {
93         return acquisitionList;
94     }
95
96     @Override
97     public void setCommonPartList(AcquisitionsCommonList acquisitionList) {
98         this.acquisitionList = acquisitionList;
99     }
100
101     @Override
102     public AcquisitionsCommon extractCommonPart(DocumentWrapper<DocumentModel> wrapDoc)
103             throws Exception {
104         throw new UnsupportedOperationException();
105     }
106
107     @Override
108     public void fillCommonPart(AcquisitionsCommon acquisitionObject, DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
109         throw new UnsupportedOperationException();
110     }
111
112     @Override
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();
117
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);
130             list.add(listItem);
131         }
132
133         return coList;
134     }
135
136     @Override
137     public void fillAllParts(DocumentWrapper<DocumentModel> wrapDoc) throws Exception {
138
139         super.fillAllParts(wrapDoc);
140         fillDublinCoreObject(wrapDoc); //dublincore might not be needed in future
141     }
142
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);
149     }
150
151
152     /**
153      * getQProperty converts the given property to qualified schema property
154      * @param prop
155      * @return
156      */
157     @Override
158     public String getQProperty(String prop) {
159         return AcquisitionConstants.NUXEO_SCHEMA_NAME + ":" + prop;
160     }
161 }
162