aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTrygve Laugstøl <trygvis@inamo.no>2012-10-07 18:50:48 +0200
committerTrygve Laugstøl <trygvis@inamo.no>2012-10-07 18:50:48 +0200
commit95f506ef0d7c2d33fff1df28e6613583e5cbf0b3 (patch)
tree485354703ab4949a113887e9e6de8dcff0ff316a
downloadapp.sh-booter-jetty-95f506ef0d7c2d33fff1df28e6613583e5cbf0b3.tar.gz
app.sh-booter-jetty-95f506ef0d7c2d33fff1df28e6613583e5cbf0b3.tar.bz2
app.sh-booter-jetty-95f506ef0d7c2d33fff1df28e6613583e5cbf0b3.tar.xz
app.sh-booter-jetty-95f506ef0d7c2d33fff1df28e6613583e5cbf0b3.zip
o Initial import of Java utils for app.sh.
-rw-r--r--.gitignore5
-rw-r--r--pom.xml34
-rw-r--r--src/main/java/io/trygvis/appsh/booter/jetty8/JettyWebServer.java108
-rw-r--r--src/main/java/io/trygvis/appsh/booter/jetty8/Main.java95
4 files changed, 242 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..a750dc8
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,5 @@
+target
+*.iml
+.idea
+.project
+.classpath
diff --git a/pom.xml b/pom.xml
new file mode 100644
index 0000000..78987d6
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0"
+ xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <parent>
+ <groupId>io.trygvis.appsh</groupId>
+ <artifactId>appsh-parent</artifactId>
+ <version>1.0-SNAPSHOT</version>
+ </parent>
+ <artifactId>booter-jetty8</artifactId>
+ <dependencies>
+ <dependency>
+ <groupId>org.eclipse.jetty</groupId>
+ <artifactId>jetty-server</artifactId>
+ <version>${versions.jetty8}</version>
+ </dependency>
+ <dependency>
+ <groupId>org.eclipse.jetty</groupId>
+ <artifactId>jetty-webapp</artifactId>
+ <version>${versions.jetty8}</version>
+ </dependency>
+ <dependency>
+ <groupId>org.eclipse.jetty.orbit</groupId>
+ <artifactId>org.apache.jasper.glassfish</artifactId>
+ <version>2.2.2.v201112011158</version>
+ </dependency>
+ <dependency>
+ <groupId>org.eclipse.jetty.orbit</groupId>
+ <artifactId>javax.el</artifactId>
+ <version>2.2.0.v201108011116</version>
+ </dependency>
+ </dependencies>
+</project>
diff --git a/src/main/java/io/trygvis/appsh/booter/jetty8/JettyWebServer.java b/src/main/java/io/trygvis/appsh/booter/jetty8/JettyWebServer.java
new file mode 100644
index 0000000..b0a3fef
--- /dev/null
+++ b/src/main/java/io/trygvis/appsh/booter/jetty8/JettyWebServer.java
@@ -0,0 +1,108 @@
+package io.trygvis.appsh.booter.jetty8;
+
+import org.eclipse.jetty.server.Connector;
+import org.eclipse.jetty.server.Server;
+import org.eclipse.jetty.server.handler.ContextHandler;
+import org.eclipse.jetty.server.handler.ContextHandlerCollection;
+import org.eclipse.jetty.server.nio.SelectChannelConnector;
+import org.eclipse.jetty.util.log.StdErrLog;
+import org.eclipse.jetty.webapp.WebAppContext;
+
+import java.io.File;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+
+public class JettyWebServer {
+ private File basedir = new File("").getAbsoluteFile();
+ private File tmp, extraClasspath;
+ private int httpPort = 8080;
+
+ List<Context> contexts = new ArrayList<Context>();
+
+ public void setBasedir(File basedir) {
+ this.basedir = basedir;
+ }
+
+ public void setHttpPort(int port) {
+ this.httpPort = port;
+ }
+
+ public Context addContext(String contextPath, File webapp) throws Exception {
+ Context context = new Context();
+ context.setContextPath(contextPath);
+ context.setWebapp(webapp);
+ contexts.add(context);
+ return context;
+ }
+
+ public void run() throws Exception {
+ tmp = new File(basedir, "tmp");
+
+ if (!tmp.isDirectory() && !tmp.mkdirs()) {
+ throw new IOException("Could not create temp directory: " + tmp);
+ }
+
+ extraClasspath = new File(basedir, "etc");
+
+ if (!extraClasspath.isDirectory()) {
+ extraClasspath = null;
+ }
+
+ System.setProperty("org.mortbay.log.class", StdErrLog.class.getName());
+
+ Server server = new Server();
+ if (httpPort != 0) {
+ Connector connector = new SelectChannelConnector();
+ connector.setPort(httpPort);
+ server.addConnector(connector);
+ }
+
+ ContextHandlerCollection handler = new ContextHandlerCollection();
+ server.setHandler(handler);
+ for (Context context : contexts) {
+ handler.addHandler(context.toJetty());
+ }
+
+ server.start();
+ server.join();
+ }
+
+ public class Context {
+ private File webapp;
+ private String contextPath;
+
+ public void setWebapp(File webapp) throws IOException {
+ if (!webapp.exists()) {
+ throw new IOException("File has to exist: " + webapp);
+ }
+ this.webapp = webapp;
+ }
+
+ public void setContextPath(String contextPath) {
+ if (!contextPath.startsWith("/")) {
+ throw new RuntimeException("The context path has to start with '/'.");
+ }
+
+ this.contextPath = contextPath;
+ }
+
+ public ContextHandler toJetty() {
+ WebAppContext context = new WebAppContext();
+ context.setContextPath(this.contextPath);
+ context.setWar(webapp.getAbsolutePath());
+ if (extraClasspath != null) {
+ context.setExtraClasspath(extraClasspath.getAbsolutePath());
+ }
+
+ context.setExtractWAR(true);
+ // TODO: Should the temp directory be cleaned out before starting?
+ String dir = contextPath.substring(1);
+ if (dir.length() == 0) {
+ dir = "ROOT";
+ }
+ context.setTempDirectory(new File(tmp, dir));
+ return context;
+ }
+ }
+}
diff --git a/src/main/java/io/trygvis/appsh/booter/jetty8/Main.java b/src/main/java/io/trygvis/appsh/booter/jetty8/Main.java
new file mode 100644
index 0000000..b69ff1d
--- /dev/null
+++ b/src/main/java/io/trygvis/appsh/booter/jetty8/Main.java
@@ -0,0 +1,95 @@
+package io.trygvis.appsh.booter.jetty8;
+
+import org.eclipse.jetty.util.IO;
+
+import java.io.*;
+import java.util.Map;
+import java.util.Properties;
+
+import static java.lang.Integer.parseInt;
+
+public class Main {
+
+ /**
+ * The file that this booter will read it's configuration from.
+ */
+ public static final String PROPERTIES_FILE = "etc/booter.properties";
+
+ public static void main(String[] args) throws Exception {
+ File basedir = new File(System.getProperty("basedir", new File("").getAbsolutePath()));
+
+ File booterPropertiesFile = new File(basedir, PROPERTIES_FILE);
+
+ Properties properties = new Properties();
+ InputStream is = null;
+ try {
+ is = new FileInputStream(booterPropertiesFile);
+ properties.load(new InputStreamReader(is, "utf-8"));
+ } catch (FileNotFoundException e) {
+ System.err.println("Can't read: " + booterPropertiesFile);
+ System.exit(1);
+ } catch (IOException e) {
+ System.err.println("Error reading: " + booterPropertiesFile);
+ System.exit(1);
+ } finally {
+ IO.close(is);
+ }
+
+ setStreams(basedir, properties);
+
+ JettyWebServer server;
+ try {
+ server = new JettyWebServer();
+ server.setBasedir(basedir);
+
+ for (Map.Entry<Object, Object> entry : properties.entrySet()) {
+ String key = entry.getKey().toString();
+ String value = entry.getValue().toString();
+
+ if (key.startsWith("context.")) {
+ server.addContext(key.substring(8), new File(basedir, value));
+ }
+ }
+
+ String httpPort = properties.getProperty("http.port");
+ if (httpPort != null) {
+ server.setHttpPort(parseInt(httpPort));
+ }
+ } catch (Exception e) {
+ System.err.println("Error while configuring Jetty.");
+ e.printStackTrace();
+ System.exit(1);
+ return;
+ }
+
+ try {
+ server.run();
+ } catch (Exception e) {
+ System.err.println("Error while starting Jetty.");
+ e.printStackTrace();
+ System.exit(1);
+ }
+ }
+
+ private static void setStreams(File basedir, Properties properties) throws IOException {
+ String logS = properties.getProperty("log");
+
+ if(logS == null) {
+ return;
+ }
+
+ File log = new File(basedir, logS);
+
+ if(!log.getParentFile().isDirectory()) {
+ if(!log.getParentFile().mkdirs()) {
+ System.err.println("Unable to create directory: " + log.getAbsolutePath());
+ System.exit(1);
+ }
+ }
+
+ PrintStream writer = new PrintStream(new FileOutputStream(log));
+
+ System.setOut(writer);
+ System.setErr(writer);
+ }
+}