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.organization.nuxeo;
26 import java.util.Iterator;
27 import java.util.List;
29 import org.collectionspace.services.OrganizationJAXBSchema;
30 import org.collectionspace.services.common.document.DocumentWrapper;
31 import org.collectionspace.services.nuxeo.client.java.RemoteDocumentModelHandler;
32 import org.collectionspace.services.nuxeo.util.NuxeoUtils;
33 import org.collectionspace.services.organization.OrganizationsCommon;
34 import org.collectionspace.services.organization.OrganizationsCommonList;
35 import org.collectionspace.services.organization.OrganizationsCommonList.OrganizationListItem;
36 import org.nuxeo.ecm.core.api.DocumentModel;
37 import org.nuxeo.ecm.core.api.DocumentModelList;
38 import org.slf4j.Logger;
39 import org.slf4j.LoggerFactory;
42 * OrganizationDocumentModelHandler
44 * $LastChangedRevision: $
47 public class OrganizationDocumentModelHandler
48 extends RemoteDocumentModelHandler<OrganizationsCommon, OrganizationsCommonList> {
50 private final Logger logger = LoggerFactory.getLogger(OrganizationDocumentModelHandler.class);
52 * organization is used to stash JAXB object to use when handle is called
53 * for Action.CREATE, Action.UPDATE or Action.GET
55 private OrganizationsCommon organization;
57 * organizationList is stashed when handle is called
60 private OrganizationsCommonList organizationList;
63 * inAuthority is the parent OrgAuthority for this context
65 private String inAuthority;
67 public String getInAuthority() {
71 public void setInAuthority(String inAuthority) {
72 this.inAuthority = inAuthority;
76 public void prepare(Action action) throws Exception {
77 //no specific action needed
81 * getCommonPart get associated organization
85 public OrganizationsCommon getCommonPart() {
90 * setCommonPart set associated organization
94 public void setCommonPart(OrganizationsCommon organization) {
95 this.organization = organization;
99 * getCommonPartList get associated organization (for index/GET_ALL)
103 public OrganizationsCommonList getCommonPartList() {
104 return organizationList;
108 public void setCommonPartList(OrganizationsCommonList organizationList) {
109 this.organizationList = organizationList;
113 public OrganizationsCommon extractCommonPart(DocumentWrapper wrapDoc)
115 throw new UnsupportedOperationException();
119 public void fillCommonPart(OrganizationsCommon organizationObject, DocumentWrapper wrapDoc) throws Exception {
120 throw new UnsupportedOperationException();
124 public OrganizationsCommonList extractCommonPartList(DocumentWrapper wrapDoc)
126 OrganizationsCommonList coList = new OrganizationsCommonList();
128 DocumentModelList docList = (DocumentModelList) wrapDoc.getWrappedObject();
130 List<OrganizationsCommonList.OrganizationListItem> list =
131 coList.getOrganizationListItem();
133 //FIXME: iterating over a long list of documents is not a long term
134 //strategy...need to change to more efficient iterating in future
135 Iterator<DocumentModel> iter = docList.iterator();
136 while(iter.hasNext()){
137 DocumentModel docModel = iter.next();
138 OrganizationListItem ilistItem = new OrganizationListItem();
139 ilistItem.setShortName(
140 (String) docModel.getProperty(getServiceContext().getCommonPartLabel("organizations"),
141 OrganizationJAXBSchema.SHORT_NAME));
142 ilistItem.setRefName(
143 (String) docModel.getProperty(getServiceContext().getCommonPartLabel("organizations"),
144 OrganizationJAXBSchema.REF_NAME));
146 * These are not currently included in the listing - only in the details
147 ilistItem.setLongName(
148 (String) docModel.getProperty(getServiceContext().getCommonPartLabel("organizations"),
149 OrganizationJAXBSchema.LONG_NAME));
150 ilistItem.setDescription(
151 (String) docModel.getProperty(getServiceContext().getCommonPartLabel("organizations"),
152 OrganizationJAXBSchema.DESCRIPTION));
154 String id = NuxeoUtils.extractId(docModel.getPathAsString());
155 ilistItem.setUri("/organizations/"+inAuthority+"/items/" + id);
156 ilistItem.setCsid(id);
160 if(logger.isDebugEnabled()){
161 logger.debug("Caught exception in extractCommonPartList", e);
169 * getQProperty converts the given property to qualified schema property
174 public String getQProperty(String prop) {
175 return OrganizationConstants.NUXEO_SCHEMA_NAME + ":" + prop;