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.caldav;
20  
21  import davmail.AbstractConnection;
22  import davmail.AbstractServer;
23  import davmail.Settings;
24  
25  import java.net.Socket;
26  
27  /**
28   * Calendar server, handle HTTP Caldav requests.
29   */
30  public class CaldavServer extends AbstractServer {
31      /**
32       * Default HTTP Caldav port
33       */
34      public static final int DEFAULT_PORT = 80;
35  
36      /**
37       * Create a ServerSocket to listen for connections.
38       * Start the thread.
39       *
40       * @param port pop listen port, 80 if not defined (0)
41       */
42      public CaldavServer(int port) {
43          super(CaldavServer.class.getName(), port, CaldavServer.DEFAULT_PORT);
44          nosslFlag = Settings.getBooleanProperty("davmail.ssl.nosecurecaldav");
45      }
46  
47      @Override
48      public String getProtocolName() {
49          return "CALDAV";
50      }
51  
52      @Override
53      public AbstractConnection createConnectionHandler(Socket clientSocket) {
54          return new CaldavConnection(clientSocket);
55      }
56  }