+ try {
+ if (conn.getLocalPort() == 143) new IMAP.Listener(auth).handleRequest(conn);
+ else if (conn.getLocalPort() == 25) new SMTP.Server().handleRequest(conn);
+ else if (conn.getLocalPort() == 119) new NNTP.Listener(auth).handleRequest(conn);
+ else if (conn.getLocalPort() == 8099) GMail.handleRequest(conn);
+ else if (conn.getLocalPort() == 8080) Jetty.instance().accept(conn);
+ else if (conn.getLocalPort() == 80) Jetty.instance().accept(conn);
+ } finally {
+ conn.close();
+ }
+ }
+
+ private static final Auth auth = new Auth();
+ private static class Auth implements Login {
+ public Account anonymous() { return null; }
+ public Object login(String user, String pass, Class protocol) {
+ //if (protocol == IMAP.class && user.endsWith("@gmail.com")) return GMail.getGMail(user, pass).getIMAP();
+ return login(user, pass);
+ }
+ public Account login(String user, String pass) {
+ //if (user.indexOf("@gmail.com") != -1) return GMail.getGMail(user, pass);
+ if (!EtcPasswd.verify(user, pass)) return null;
+ final Mailbox root =
+ FileBasedMailbox.getFileBasedMailbox(Mailbox.STORAGE_ROOT + "/user", true);
+ return new Account(user, null, root.slash(user, true)){
+ public Mailbox getMailbox(Class protocol) {
+ /*
+ if (protocol == NNTP.class) {
+ final Mailbox arch = new MailmanArchives();
+ return new Mailbox.Default() {
+ public void add(Message m) { throw new RuntimeException("not supported"); }
+ public void add(Message m, int i) { throw new RuntimeException("not supported"); }
+ public int uidValidity() { return 1; }
+ public Mailbox.Iterator iterator() { return null; }
+ public int uidNext() { return 0; }
+ public String[] children() { return new String[] { "us" }; }
+ public Mailbox slash(String name, boolean create) { return arch; }
+ };
+ } else {
+ */
+ return super.getMailbox(protocol);
+ //}
+ }
+ };