mschaefer@9125: /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde mschaefer@9125: * Software engineering by mschaefer@9125: * Björnsen Beratende Ingenieure GmbH mschaefer@9125: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt mschaefer@9125: * mschaefer@9125: * This file is Free Software under the GNU AGPL (>=v3) mschaefer@9125: * and comes with ABSOLUTELY NO WARRANTY! Check out the mschaefer@9125: * documentation coming with Dive4Elements River for details. mschaefer@9125: */ mschaefer@9125: mschaefer@9125: package org.dive4elements.river.artifacts.sinfo.collision; mschaefer@9125: mschaefer@9125: import java.util.ArrayList; mschaefer@9125: import java.util.List; mschaefer@9125: mschaefer@9125: import org.apache.log4j.Logger; mschaefer@9125: import org.dive4elements.artifactdatabase.state.DefaultOutput; mschaefer@9125: import org.dive4elements.artifactdatabase.state.Facet; mschaefer@9125: import org.dive4elements.artifactdatabase.state.FacetActivity; mschaefer@9125: import org.dive4elements.artifacts.Artifact; mschaefer@9125: import org.dive4elements.artifacts.ArtifactFactory; mschaefer@9125: import org.dive4elements.artifacts.CallMeta; mschaefer@9125: import org.dive4elements.artifacts.common.utils.XMLUtils; mschaefer@9125: import org.dive4elements.river.artifacts.AbstractStaticStateArtifact; mschaefer@9125: import org.dive4elements.river.artifacts.D4EArtifact; mschaefer@9125: import org.dive4elements.river.artifacts.model.FacetTypes; mschaefer@9125: import org.dive4elements.river.artifacts.sinfo.common.CollisionCountProcessor; mschaefer@9125: import org.dive4elements.river.artifacts.states.StaticState; mschaefer@9125: import org.w3c.dom.Document; mschaefer@9125: mschaefer@9125: /** mschaefer@9125: * Display of a river bed collision data series loaded from database mschaefer@9125: * mschaefer@9125: * @author Matthias Schäfer mschaefer@9125: * mschaefer@9125: */ mschaefer@9125: public class CollisionArtifact extends AbstractStaticStateArtifact implements FacetTypes { mschaefer@9125: mschaefer@9157: private static final long serialVersionUID = 1L; mschaefer@9157: mschaefer@9125: /** The log for this class. */ mschaefer@9125: private static Logger log = Logger.getLogger(CollisionArtifact.class); mschaefer@9125: mschaefer@9125: /** Artifact name. */ mschaefer@9125: private static final String NAME = "collision"; mschaefer@9125: mschaefer@9125: static { mschaefer@9125: // TODO: Move to configuration. mschaefer@9125: FacetActivity.Registry.getInstance().register(NAME, FacetActivity.INACTIVE); mschaefer@9125: } mschaefer@9125: mschaefer@9125: public static final String STATIC_STATE_NAME = "state.collision.static"; mschaefer@9125: mschaefer@9125: /** mschaefer@9125: * Trivial Constructor. mschaefer@9125: */ mschaefer@9125: public CollisionArtifact() { mschaefer@9125: log.debug("new CollisionArtifact"); mschaefer@9125: } mschaefer@9125: mschaefer@9125: @Override mschaefer@9125: public String getName() { mschaefer@9125: return NAME; mschaefer@9125: } mschaefer@9125: mschaefer@9125: /** mschaefer@9125: * Gets called from factory, to set things up. mschaefer@9125: */ mschaefer@9125: @Override mschaefer@9125: public void setup(final String identifier, final ArtifactFactory factory, final Object context, final CallMeta callMeta, final Document data, mschaefer@9125: final List loadFacets) { mschaefer@9125: mschaefer@9125: log.debug("CollisionArtifact.setup"); mschaefer@9125: mschaefer@9125: if (log.isDebugEnabled()) { mschaefer@9125: log.debug(XMLUtils.toString(data)); mschaefer@9125: } mschaefer@9125: mschaefer@9125: final String code = getDatacageIDValue(data); mschaefer@9125: final String[] parts = code.split("-"); mschaefer@9125: if (parts.length >= 2) mschaefer@9125: addStringData("collision_id", parts[1]); mschaefer@9125: if (parts.length >= 3) mschaefer@9125: addStringData("year", parts[2]); mschaefer@9125: else mschaefer@9125: addStringData("year", "jahr?"); mschaefer@9125: String seriesName; mschaefer@9125: if (parts.length >= 4) mschaefer@9125: seriesName = parts[3]; mschaefer@9125: else mschaefer@9125: seriesName = "name?"; mschaefer@9125: mschaefer@9125: createFacets(callMeta, code, seriesName, getDataAsString("year")); mschaefer@9125: mschaefer@9125: super.setup(identifier, factory, context, callMeta, data, loadFacets); mschaefer@9125: } mschaefer@9125: mschaefer@9125: private void createFacets(final CallMeta callMeta, final String code, final String seriesName, final String year) { mschaefer@9125: if (code == null) mschaefer@9125: return; mschaefer@9125: final String[] parts = code.split("-"); mschaefer@9125: if (parts.length < 2) { mschaefer@9125: log.error("Invalid datacage ID '" + code + "'"); mschaefer@9125: return; mschaefer@9125: } mschaefer@9125: final ArrayList facets = new ArrayList<>(2); mschaefer@9125: facets.add(CollisionCountProcessor.createFacet(callMeta, year)); mschaefer@9125: // facets.add(CollisionGaugeWProcessor.createFacet(callMeta, seriesName)); //REMARK gauge_w is the cm above gauge datum, mschaefer@9125: // therefore only useful with transformation to NHN mschaefer@9125: addFacets(STATIC_STATE_NAME, facets); mschaefer@9125: } mschaefer@9125: mschaefer@9125: @Override mschaefer@9125: protected void initStaticState() { mschaefer@9125: mschaefer@9125: log.debug("initStaticState " + getName() + " " + identifier()); mschaefer@9125: mschaefer@9125: final StaticState state = new StaticState(STATIC_STATE_NAME); mschaefer@9125: final DefaultOutput output = new DefaultOutput("general", "general", "image/png", "chart"); mschaefer@9125: mschaefer@9125: final List facets = getFacets(STATIC_STATE_NAME); mschaefer@9125: output.addFacets(facets); mschaefer@9125: state.addOutput(output); mschaefer@9125: mschaefer@9125: setStaticState(state); mschaefer@9125: } mschaefer@9125: mschaefer@9125: @Override mschaefer@9125: protected void initialize(final Artifact artifact, final Object context, final CallMeta meta) { mschaefer@9125: // do not clone facets, etc. from master artifact mschaefer@9125: mschaefer@9125: log.debug("initialize"); mschaefer@9125: importData((D4EArtifact) artifact, "river"); mschaefer@9125: importData((D4EArtifact) artifact, "ld_from"); mschaefer@9125: importData((D4EArtifact) artifact, "ld_to"); mschaefer@9125: mschaefer@9125: log.debug("ld_from " + getDataAsString("ld_from")); mschaefer@9125: log.debug("ld_to " + getDataAsString("ld_to")); mschaefer@9125: } mschaefer@9125: }