Mercurial > dive4elements > framework
view artifact-database/src/main/java/de/intevation/artifactdatabase/rest/Standalone.java @ 57:cf9848c85755 0.2
RELEASE 0.2: Summarized NEWS and Changes
artifacts/trunk@338 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Hans Plum <hans.plum@intevation.de> |
---|---|
date | Fri, 13 Nov 2009 18:37:51 +0000 |
parents | 4ae4dc99127d |
children | 48d1a9a082c2 |
line wrap: on
line source
package de.intevation.artifactdatabase.rest; import org.restlet.Component; import org.restlet.data.Protocol; import de.intevation.artifacts.ArtifactDatabase; import de.intevation.artifactdatabase.Config; import de.intevation.artifactdatabase.rest.RestApp; import org.apache.log4j.Logger; /** * @author Sascha L. Teichmann (sascha.teichmann@intevation) */ public class Standalone { private static Logger logger = Logger.getLogger(Standalone.class); public static final String REST_PORT = "/artifact-database/rest-server/port/text()"; public static final String LISTEN_INTERFACE = "/artifact-database/rest-server/listen/text()"; public static final int DEFAULT_PORT = 8181; public static void startAsServer(ArtifactDatabase db) { String portString = Config.getStringXPath(REST_PORT); String listenString = Config.getStringXPath(LISTEN_INTERFACE); int port = DEFAULT_PORT; if (portString != null) { try { port = Integer.parseInt(portString); if (port < 0) { throw new NumberFormatException(); } } catch (NumberFormatException nfe) { logger.error("rest port is not a positive integer value.", nfe); return; } } RestApp app = new RestApp(db); Component component = new Component(); if (listenString != null) { component.getServers().add(Protocol.HTTP, listenString, port); } else { component.getServers().add(Protocol.HTTP, port); } component.getDefaultHost().attach(app); logger.info("Starting rest HTTP server on " + (listenString != null ? listenString : "*") + ":" + port); try { component.start(); } catch (Exception e) { logger.error(e.getLocalizedMessage(), e); } } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8: