view artifacts/src/main/java/org/dive4elements/river/artifacts/datacage/templating/App.java @ 8927:04ad2cfce559

ANother comment
author gernotbelger
date Thu, 01 Mar 2018 17:45:49 +0100
parents 7de3837b204c
children dbb26bc81843
line wrap: on
line source
/* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
 * Software engineering by Intevation GmbH
 *
 * This file is Free Software under the GNU AGPL (>=v3)
 * and comes with ABSOLUTELY NO WARRANTY! Check out the
 * documentation coming with Dive4Elements River for details.
 */

package org.dive4elements.river.artifacts.datacage.templating;

import java.util.Map;
import java.util.HashMap;

import java.io.IOException;
import java.io.OutputStream;
import java.net.MalformedURLException;
import java.io.File;
import java.io.FileOutputStream;

import org.dive4elements.river.backend.SessionFactoryProvider;

import org.hibernate.Session;
import org.slf4j.bridge.SLF4JBridgeHandler;
import org.w3c.dom.Document;

import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.dive4elements.artifacts.common.utils.Config;
import org.dive4elements.artifacts.common.utils.XMLUtils;

import org.dive4elements.river.artifacts.datacage.Recommendations;

public class App
{
    private static Logger log = Logger.getLogger(App.class);

    /**
     * The logging is done via Log4j. To configure the logging
     * a file 'log4j.properties' is search in the configuration directory.
     */
    private static final String LOG4J_PROPERTIES = "log4j.properties";
    
    public static final String template =
        System.getProperty("meta.data.template", "meta-data.xml");

    public static final String userId =
        System.getProperty("user.id");

    public static final String PARAMETERS =
        System.getProperty("meta.data.parameters", "");

    public static final String OUTPUT =
        System.getProperty("meta.data.output");

    public static Map<String, Object> getParameters() {
        HashMap<String, Object> map = new HashMap<String, Object>();
        String [] parts = PARAMETERS.split("\\s*;\\s*");
        for (String part: parts) {
            String [] kv = part.split("\\s*:\\s*");
            if (kv.length < 2 || (kv[0] = kv[0].trim()).length() == 0) {
                continue;
            }
            String [] values = kv[1].split("\\s*,\\s*");
            map.put(kv[0], values.length == 1 ? values[0] : values);
        }
        return map;
    }

    /**
     * Trys to load the Log4j configuration from ${config.dir}/log4j.properties.
     */
    private static final void configureLogging() {
        File configDir = Config.getConfigDirectory();
        File propFile = new File(configDir, LOG4J_PROPERTIES);

        if (propFile.isFile() && propFile.canRead()) {
            try {
                PropertyConfigurator.configure(propFile.toURI().toURL());
                SLF4JBridgeHandler.install();
            }
            catch (MalformedURLException mue) {
                mue.printStackTrace(System.err);
            }
        }
    }
    
    public static void main(String [] args) {

        configureLogging();
        
        Recommendations rec = Recommendations.createRecommendations(
            new File(template));

        if (rec == null) {
            System.err.println("No recommendations created");
            return;
        }

        final Document result = XMLUtils.newDocument();

        final Map<String, Object> parameters = getParameters();
        // REMARK/TODO: 'ARTIFACT-OUTS' needs a String-Array, should be handled by parser
        parameters.put("ARTIFACT-OUTS", new String[] { "LONGITUDINAL_SECTION" });
        parameters.put("PARAMETERS", parameters);
        parameters.put("USER-ID", userId);

        Session session = SessionFactoryProvider
            .createSessionFactory()
            .openSession();

        try {
            rec.recommend(parameters, userId, result, session);
        }
        finally {
            session.close();
        }

        OutputStream out;

        if (OUTPUT == null) {
            out = System.out;
        }
        else {
            try {
                out = new FileOutputStream(OUTPUT);
            }
            catch (IOException ioe) {
                log.error(ioe);
                return;
            }
        }

        try {
            out.write('\n');
            XMLUtils.toStream(result, out);
            out.write('\n');
        }
        catch (IOException e) {
            log.error(e);
        }
        finally {
            if (OUTPUT != null) {
                try {
                    out.close();
                }
                catch (IOException ioe) {
                    log.error(ioe);
                }
            }
        }
        System.exit(0);
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org