/** * The contents of this file are subject to the license and copyright * detailed in the LICENSE and NOTICE files at the root of the source * tree and available online at * * http://www.dspace.org/license/ */ package org.dspace.sword2; import org.apache.abdera.i18n.iri.IRI; import org.dspace.content.DSpaceObject; import org.dspace.content.Community; import org.apache.log4j.Logger; import org.dspace.core.Context; import org.dspace.handle.HandleManager; import org.swordapp.server.SwordCollection; public class CommunityCollectionGenerator implements AtomCollectionGenerator { private static Logger log = Logger.getLogger(CommunityCollectionGenerator.class); public SwordCollection buildCollection(Context context, DSpaceObject dso, SwordConfigurationDSpace swordConfig) throws DSpaceSwordException { if (!(dso instanceof Community)) { log.error("buildCollection passed something other than a Community object"); throw new DSpaceSwordException("Incorrect ATOMCollectionGenerator instantiated"); } // get the things we need out of the service SwordUrlManager urlManager = swordConfig.getUrlManager(context, swordConfig); Community com = (Community) dso; SwordCollection scol = new SwordCollection(); // prepare the parameters to be put in the sword collection String location = urlManager.getDepositLocation(com); if (location == null) { location = HandleManager.getCanonicalForm(com.getHandle()); } scol.setLocation(location); // collection title is just the community name String title = com.getMetadata("name"); if (title != null && !"".equals(title)) { scol.setTitle(title); } // FIXME: the community has no obvious licence // the collection policy is the licence to which the collection adheres // String collectionPolicy = col.getLicense(); // abstract is the short description of the collection String dcAbstract = com.getMetadata("short_description"); if (dcAbstract != null && !"".equals(dcAbstract)) { scol.setAbstract(dcAbstract); } // do we support mediated deposit scol.setMediation(swordConfig.isMediated()); // NOTE: for communities, there are no MIME types that it accepts. // the list of mime types that we accept // offer up the collections from this item as deposit targets String subService = urlManager.constructSubServiceUrl(com); scol.addSubService(new IRI(subService)); log.debug("Created ATOM Collection for DSpace Community"); return scol; } }