View Javadoc
1   /*
2    * DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
3    * Copyright (C) 2009  Mickael Guessant
4    *
5    * This program is free software; you can redistribute it and/or
6    * modify it under the terms of the GNU General Public License
7    * as published by the Free Software Foundation; either version 2
8    * of the License, or (at your option) any later version.
9    *
10   * This program is distributed in the hope that it will be useful,
11   * but WITHOUT ANY WARRANTY; without even the implied warranty of
12   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13   * GNU General Public License for more details.
14   *
15   * You should have received a copy of the GNU General Public License
16   * along with this program; if not, write to the Free Software
17   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
18   */
19  package davmail.ldap;
20  
21  import davmail.AbstractConnection;
22  import davmail.AbstractServer;
23  import davmail.Settings;
24  
25  import java.net.Socket;
26  
27  /**
28   * LDAP server, handle LDAP directory requests.
29   */
30  public class LdapServer extends AbstractServer {
31      /**
32       * Default LDAP port
33       */
34      public static final int DEFAULT_PORT = 389;
35  
36      /**
37       * Create a ServerSocket to listen for connections.
38       * Start the thread.
39       *
40       * @param port pop listen port, 389 if not defined (0)
41       */
42      public LdapServer(int port) {
43          super(LdapServer.class.getName(), port, LdapServer.DEFAULT_PORT);
44          nosslFlag = Settings.getBooleanProperty("davmail.ssl.nosecureldap");
45      }
46  
47      @Override
48      public String getProtocolName() {
49          return "LDAP";
50      }
51  
52      @Override
53      public AbstractConnection createConnectionHandler(Socket clientSocket) {
54          return new LdapConnection(clientSocket);
55      }
56  }