Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/collections/OutputParser.java @ 644:02c0cce0e469
Introduce a cache for the distance-info service
flys-artifacts/trunk@2028 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Mon, 30 May 2011 11:34:06 +0000 |
parents | 6167ae622ce0 |
children | 68c6c75a6f7c |
line wrap: on
line source
package de.intevation.flys.collections; import java.util.HashMap; import java.util.Map; import javax.xml.xpath.XPathConstants; import org.apache.log4j.Logger; import org.w3c.dom.Document; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import de.intevation.artifacts.ArtifactDatabase; import de.intevation.artifacts.ArtifactDatabaseException; import de.intevation.artifacts.ArtifactNamespaceContext; import de.intevation.artifacts.CallMeta; import de.intevation.artifactdatabase.state.DefaultOutput; import de.intevation.artifactdatabase.state.Output; import de.intevation.artifacts.common.utils.XMLUtils; import de.intevation.flys.artifacts.model.ManagedFacet; public class OutputParser { /** Constant XPath that points to the outputmodes of an artifact.*/ public static final String XPATH_ARTIFACT_OUTPUTMODES = "/art:result/art:outputmodes/art:output"; private static Logger logger = Logger.getLogger(OutputParser.class); protected ArtifactDatabase db; protected CallMeta meta; protected Map<String, Output> outs; public OutputParser(ArtifactDatabase db, CallMeta meta) { this.db = db; this.meta = meta; this.outs = new HashMap<String, Output>(); } public void parse(String uuid) throws ArtifactDatabaseException { logger.debug("OutputParser.parse: " + uuid); // XXX I am not sure if it works well every time with an empty // document in the describe operation of an artifact. Document description = db.describe(uuid, null, meta); NodeList outs = (NodeList) XMLUtils.xpath( description, XPATH_ARTIFACT_OUTPUTMODES, XPathConstants.NODESET, ArtifactNamespaceContext.INSTANCE); int num = outs != null ? outs.getLength() : 0; logger.debug("Artifact has " + num + " outputs."); for (int i = 0; i < num; i++) { Node out = outs.item(i); parseOutput(uuid, out); } } public Map<String, Output> getOuts() { return outs; } protected void addItem(String out, ManagedFacet item) { Output o = outs.get(out); if (o != null) { int num = o.getFacets().size(); item.setPosition(num+1); o.addFacet(item); } } protected void parseOutput(String uuid, Node out) { String name = XMLUtils.xpathString( out, "@art:name", ArtifactNamespaceContext.INSTANCE); if (outs.get(name) == null) { logger.debug("Create new output: " + name); newOutput(out, name); } parseItems(uuid, out, name); } protected void newOutput(Node out, String name) { String desc = XMLUtils.xpathString( out, "@art:description", ArtifactNamespaceContext.INSTANCE); String mimetype = XMLUtils.xpathString( out, "@art:mime-type", ArtifactNamespaceContext.INSTANCE); Output o = new DefaultOutput(name, desc, mimetype); outs.put(name, o); } protected void parseItems(String uuid, Node out, String outname) { NodeList facets = (NodeList) XMLUtils.xpath( out, "art:facets/art:facet", XPathConstants.NODESET, ArtifactNamespaceContext.INSTANCE); int num = facets != null ? facets.getLength() : 0; logger.debug("Output has " + num + " facets."); for (int i = 0; i < num; i++) { Node facet = facets.item(i); String name = XMLUtils.xpathString( facet, "@art:name", ArtifactNamespaceContext.INSTANCE); ManagedFacet item = new ManagedFacet(name, null, uuid, 1, 1); addItem(outname, item); } } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :