X-Git-Url: http://git.megacz.com/?p=org.ibex.jinetd.git;a=blobdiff_plain;f=src%2Forg%2Fibex%2Fjinetd%2FMain.java;h=7e3b08d793879855520a683101f216c431c4363c;hp=8e4c41b84f6188eff3c690b9ac90c3a49d935683;hb=c28d954263d3a9b5f8ea3ff37368ae811ff48f6c;hpb=501b9089d3cf777fc417d9bcddba9bc542a086f9 diff --git a/src/org/ibex/jinetd/Main.java b/src/org/ibex/jinetd/Main.java index 8e4c41b..7e3b08d 100644 --- a/src/org/ibex/jinetd/Main.java +++ b/src/org/ibex/jinetd/Main.java @@ -13,12 +13,20 @@ public class Main { // Bootup ////////////////////////////////////////////////////////////////////////////// + static { + System.setProperty("java.awt.headless", "true"); + System.setProperty("ibex.log.stackTraces", "true"); + System.setProperty("ibex.log.notes.on", "false"); + System.setProperty("org.mortbay.xml.XmlParser.NotValidating", "true"); + System.setProperty("STOP.PORT", "0"); + } + public static String ROOT; - public static String LOGFILE; - public static PrintStream LOGSTREAM; + private static String LOGFILE; + private static PrintStream LOGSTREAM; public static String defaultDomain; - static { + public static void init() { try { System.err.println("jinetd starting..."); ROOT = System.getProperty("jinetd.root", null); @@ -30,17 +38,71 @@ public class Main { defaultDomain = localMachine.getHostName(); } catch(java.net.UnknownHostException uhe) { defaultDomain = "localhost"; } System.err.println(" jinetd.hostname = " + defaultDomain); - LOGFILE = System.getProperty("jinetd.logfile", ROOT + File.separatorChar+"log.txt"); - System.err.println(" jinetd.logfile = " + LOGFILE); - System.err.println(" redirecting stdout/stderr to logfile." + LOGFILE); - LOGSTREAM = new PrintStream(new FileOutputStream(LOGFILE, true)); - System.setErr(LOGSTREAM); - System.setOut(LOGSTREAM); + LOGFILE = System.getProperty("jinetd.logfile", /*ROOT + File.separatorChar+"log.txt"*/null); + if (LOGFILE != null) { + System.err.println(" jinetd.logfile = " + LOGFILE); + System.err.println(" redirecting stdout/stderr to logfile." + LOGFILE); + LOGSTREAM = new PrintStream(new FileOutputStream(LOGFILE, true)); + System.setErr(LOGSTREAM); + System.setOut(LOGSTREAM); + } + + gatherDependencies(); } catch (Throwable e) { throw new Error(e); } } + private static void depend(String name, String url) throws Exception { + File f = new File(ROOT + File.separatorChar + "lib" + File.separatorChar + name); + if (f.exists()) return; + Log.warn(Main.class, "attempting to fetch " + name); + File fminus = new File(ROOT + File.separatorChar + "lib" + File.separatorChar + name + "-"); + GetDep.fetch(fminus.getAbsolutePath(), url); + fminus.renameTo(f); + } + + // FIXME: really need some hashes in here for security + private static void gatherDependencies() throws Exception { + depend("bcel-5.1.jar", + "tgz:http://apache.cs.utah.edu/jakarta/bcel/binaries/bcel-5.1.tar.gz!bcel-5.1/bcel-5.1.jar"); + + depend("commons-el.jar", + "tgz:http://www.signal42.com/mirrors/apache/jakarta/commons/el/binaries/commons-el-1.0.tar.gz!"+ + "commons-el-1.0/commons-el.jar"); + + depend("commons-logging.jar", + "tgz:http://apache.towardex.com/jakarta/commons/logging/binaries/commons-logging-1.0.4.tar.gz!"+ + "commons-logging-1.0.4/commons-logging.jar"); + + depend("org.mortbay.jetty.jar", + "zip:http://voxel.dl.sourceforge.net/sourceforge/jetty/jetty-5.1.2.zip!jetty-5.1.2/lib/org.mortbay.jetty.jar"); + depend("javax.servlet.jar", + "zip:http://voxel.dl.sourceforge.net/sourceforge/jetty/jetty-5.1.2.zip!jetty-5.1.2/lib/javax.servlet.jar"); + + depend("prevayler-2.02.005.jar", + "tgz:http://unc.dl.sourceforge.net/sourceforge/prevayler/prevayler-2.02.005.tar.gz!"+ + "prevayler-2.02.005/prevayler-2.02.005.jar"); + + depend("jasper-runtime.jar", + "tgz:http://www.reverse.net/pub/apache/jakarta/tomcat-5/v5.5.8/bin/jakarta-tomcat-5.5.8.tar.gz!"+ + "jakarta-tomcat-5.5.8/common/lib/jasper-runtime.jar"); + depend("jasper-compiler.jar", + "tgz:http://www.reverse.net/pub/apache/jakarta/tomcat-5/v5.5.8/bin/jakarta-tomcat-5.5.8.tar.gz!"+ + "jakarta-tomcat-5.5.8/common/lib/jasper-compiler.jar"); + depend("jasper-compiler-jdt.jar", + "tgz:http://www.reverse.net/pub/apache/jakarta/tomcat-5/v5.5.8/bin/jakarta-tomcat-5.5.8.tar.gz!"+ + "jakarta-tomcat-5.5.8/common/lib/jasper-compiler-jdt.jar"); + + depend("xpp3_min-1.1.3.4.I.jar", + "http://www.extreme.indiana.edu/dist/java-repository/xpp3/jars/xpp3_min-1.1.3.4.I.jar"); + depend("xstream.jar", + "http://dist.codehaus.org/xstream/jars/xstream-1.1.1.jar"); + depend("skaringa-r3p5.jar", + "tgz:http://unc.dl.sourceforge.net/sourceforge/skaringa/skaringa-r3p5.tar.gz!"+ + "skaringa/lib/skaringa-r3p5.jar"); + } + private static String autoDetectRoot() throws Exception { if (!(Main.class.getClassLoader() instanceof URLClassLoader)) throw new Error("unable to detect jinetd.root because my ClassLoader is not an instanceof URLClassLoader"); @@ -69,7 +131,16 @@ public class Main { System.exit(0); } + private static TreeClassLoader rootClassLoader; + public static TreeClassLoader getRootClassLoader() { + if (rootClassLoader==null) + rootClassLoader = new TreeClassLoader(new File(ROOT + File.separatorChar + "lib"), + Main.class.getClassLoader()); + return rootClassLoader; + } + public static void main(String[] s) throws Exception { + init(); Root root = new Root(ROOT); while(true) try { if (root != null) { root.scan(); return; }