public class Main implements Listener {
public void accept(Connection conn) {
- Log.error(this, "connection port is " + conn.getLocalPort());
- if (conn.getLocalPort() == 25) { new SMTP.Server().handleRequest(conn);
- } else if (conn.getLocalPort() == 143) { new IMAP.Listener().handleRequest(conn);
- } else if (conn.getLocalPort() == 119) { new NNTP.Listener().handleRequest(conn);
+ 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);
+ } 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);
+ }
+ }
+ };
}
- conn.close();
}
}