Mercurial > dive4elements > river
view flys-client/src/main/java/de/intevation/flys/client/server/UserCollectionsServiceImpl.java @ 1330:ece7d9484574
Added missing string resources for datacage.
flys-client/trunk@2974 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Fri, 14 Oct 2011 14:01:32 +0000 |
parents | ba1b27b7d282 |
children | ab8eb2f544f2 |
line wrap: on
line source
package de.intevation.flys.client.server; import java.util.ArrayList; import java.util.Date; import java.util.List; import javax.xml.xpath.XPathConstants; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NodeList; import com.google.gwt.user.server.rpc.RemoteServiceServlet; import de.intevation.artifacts.common.ArtifactNamespaceContext; import de.intevation.artifacts.common.utils.XMLUtils; import de.intevation.artifacts.httpclient.exceptions.ConnectionException; import de.intevation.artifacts.httpclient.http.HttpClient; import de.intevation.artifacts.httpclient.http.HttpClientImpl; import de.intevation.flys.client.shared.model.Collection; import de.intevation.flys.client.shared.model.DefaultCollection; import de.intevation.flys.client.client.services.UserCollectionsService; /** * This service returns a list of collections owned by a specified user. * <b>NOTE:</b> The Collections returned by this service provide no information * about the CollectionItems or OutputModes of the Collection. You need to fetch * these information explicitly using another service. * * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class UserCollectionsServiceImpl extends RemoteServiceServlet implements UserCollectionsService { public Collection[] getUserCollections( String serverUrl, String locale, String userid) { System.out.println("UserCollectionsServiceImpl.getUserCollections"); HttpClient client = new HttpClientImpl(serverUrl, locale); try { Document result = client.listUserCollections(userid); NodeList list = (NodeList) XMLUtils.xpath( result, "/art:artifact-collections/art:artifact-collection", XPathConstants.NODESET, ArtifactNamespaceContext.INSTANCE); if (list == null || list.getLength() == 0) { System.out.println("No collection found for user: " + userid); return null; } int num = list.getLength(); List<Collection> all = new ArrayList<Collection>(num); for (int i = 0; i < num; i++) { Collection c = createCollection((Element) list.item(i)); if (c != null) { all.add(c); } } System.out.println("User has " + all.size() + " collections."); return (Collection[]) all.toArray(new Collection[all.size()]); } catch (ConnectionException ce) { System.err.println(ce.getLocalizedMessage()); } System.err.println("No user collections found."); return null; } /** * Extracts a SimpleCollection from <i>node</i>. * * @param node Contains information about a collection. * * @return a list of Simplecollections. */ protected Collection createCollection(Element node) { String uri = ArtifactNamespaceContext.NAMESPACE_URI; String creationStr = node.getAttributeNS(uri, "creation"); String name = node.getAttributeNS(uri, "name"); String uuid = node.getAttributeNS(uri, "uuid"); String ttlStr = node.getAttributeNS(uri, "ttl"); if (uuid != null && ttlStr != null) { try { long time = Long.parseLong(creationStr); long ttl = Long.parseLong(ttlStr); return new DefaultCollection(uuid, ttl, name, new Date(time)); } catch (NumberFormatException nfe) { System.err.println("Error while parsing collection attributes."); return null; } } System.err.println("Found an invalid Collection."); return null; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :