import org.ibex.mail.target.*;
import org.ibex.mail.protocol.*;
import org.ibex.util.*;
-import org.ibex.jinetd.*;
import org.ibex.jetty.*;
import org.ibex.io.*;
import java.io.*;
import java.util.*;
import org.ibex.crypto.*;
import org.ibex.jetty.*;
+import javax.net.ssl.SSLServerSocket;
+import javax.net.ssl.SSLServerSocketFactory;
+import javax.net.ssl.SSLSocket;
-public class Main implements Listener {
+public class Main {
public static void main(String[] s) throws Exception {
+ try {
+ File f = new File(Mailbox.STORAGE_ROOT + "/restart");
+ if (f.exists()) f.delete();
+ } catch (Exception e) { Log.error(Main.class, e); }
new Main().main();
}
public void main() throws Exception {
- ServerSocket sock143 = new ServerSocket(143);
- ServerSocket sock119 = new ServerSocket(119);
- ServerSocket sock25 = new ServerSocket(25);
+ if (System.getProperty("javax.net.ssl.keyStore")==null)
+ System.setProperty("javax.net.ssl.keyStore", Mailbox.STORAGE_ROOT+"/conf/ssl/ssl.keystore");
+ if (System.getProperty("javax.net.ssl.keyStorePassword")==null)
+ System.setProperty("javax.net.ssl.keyStorePassword", "changeit");
+ SSLServerSocketFactory sslserversocketfactory =
+ (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
+ ServerSocket sslserversocket =
+ (ServerSocket) sslserversocketfactory.createServerSocket(9999);
+ ServerSocket sock143 = new ServerSocket(143);
+ ServerSocket sock119 = new ServerSocket(119);
+ ServerSocket sock25 = new ServerSocket(25);
+ ServerSocket sock8025 = new ServerSocket(8025);
+ ServerSocket sock993 = new ServerSocket(993);
+ ServerSocket sock563 = new ServerSocket(563);
+ //ServerSocket sock995 = new ServerSocket(995);
+ //ServerSocket sock113 = new ServerSocket(113);
+ new Thread() {
+ public void run() {
+ while(true) {
+ try { Thread.sleep(500); } catch (Exception e) { }
+ try {
+ File f = new File(Mailbox.STORAGE_ROOT + "/restart");
+ if (f.exists()) {
+ Log.error("RESTART", "restarting...");
+ System.exit(0);
+ }
+ } catch (Exception e) { Log.error(this, e); }
+ }
+ }
+ }.start();
new Acceptor(sock143).start();
new Acceptor(sock119).start();
new Acceptor(sock25).start();
+ new Acceptor(sock8025).start();
+ new Acceptor(sock993).start();
+ new Acceptor(sock563).start();
+ //new Acceptor(sock995).start();
+ //new Acceptor(sock113).start();
}
private class Acceptor extends Thread {
}
}
- public boolean accept(Connection conn) {
+ public void accept(Connection conn) {
try {
if (conn.getLocalPort() == 143) new IMAP.Listener(auth).handleRequest(conn);
+ else if (conn.getLocalPort() == 993) new IMAP.Listener(auth).handleRequest(conn);
else if (conn.getLocalPort() == 119) new NNTP.Listener(auth).handleRequest(conn);
+ else if (conn.getLocalPort() == 563) new NNTP.Listener(auth).handleRequest(conn);
else if (conn.getLocalPort() == 25) new SMTP.Server().handleRequest(conn);
+ else if (conn.getLocalPort() == 8025) SMTP.whitelist.handleRequest(conn);
//else if (conn.getLocalPort() == 110) new POP3.Listener(auth).handleRequest(conn);
+ //else if (conn.getLocalPort() == 995) new POP3.Listener(auth).handleRequest(conn);
//else if (conn.getLocalPort() == 8099) GMail.handleRequest(conn);
- else return false;
- return true;
+ } catch (Stream.Closed c) {
+ Log.error(this, "connection abruptly closed by client");
+ } catch (IOException e) {
+ Log.error(this, e);
} finally {
conn.close();
}
private static final Auth auth = new Auth();
private static class Auth implements Login {
+ private KerberosAuth ka = new KerberosAuth("MEGACZ.COM", "godel.megacz.com");
public Account anonymous() {
try {
final Mailbox root =
public Object login(String user, String pass, Class protocol) { return login(user, pass); }
public Account login(String user, String pass) {
if (!EtcPasswd.verify(user, pass)) return null;
+
+ // currently broken, but should be used
+ //if (!ka.auth(user, pass)) return null;
+
final Mailbox root =
FileBasedMailbox.getFileBasedMailbox(Mailbox.STORAGE_ROOT + "/user", true);
return new Account(user, null, root.slash(user, true)){