01: /**
02: * Copyright (c) 2000/2001 Thomas Kopp
03: * All rights reserved.
04: *
05: * Redistribution and use in source and binary forms, with or without
06: * modification, are permitted provided that the following conditions
07: * are met:
08: * 1. Redistributions of source code must retain the above copyright
09: * notice, this list of conditions and the following disclaimer.
10: * 2. Redistributions in binary form must reproduce the above copyright
11: * notice, this list of conditions and the following disclaimer in the
12: * documentation and/or other materials provided with the distribution.
13: *
14: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17: * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24: * SUCH DAMAGE.
25: */package org.w3c.jigsaw.https.socket;
26:
27: import java.net.Socket;
28:
29: import javax.net.ssl.SSLSession;
30: import javax.net.ssl.SSLSocket;
31:
32: import org.w3c.jigsaw.http.httpd;
33: import org.w3c.jigsaw.http.socket.SocketClient;
34: import org.w3c.jigsaw.http.socket.SocketClientFactory;
35: import org.w3c.jigsaw.http.socket.SocketClientState;
36:
37: /**
38: * @author Thomas Kopp, Dialogika GmbH
39: * @version 1.1, 6 February 2004
40: *
41: * This class extends a Jigsaw SocketClient designed for the
42: * http protocol
43: * in order to supply a SocketClient for the https protocol including
44: * client authentication in accordance with the JSSE API.
45: */
46: public class SSLSocketClient extends SocketClient {
47:
48: /**
49: * Creates an empty client.
50: *
51: * @param server the target http(s( daemon
52: * @param pool the client factory in use
53: * @param state the socket cliente state in use
54: */
55:
56: protected SSLSocketClient(httpd server, SocketClientFactory pool,
57: SocketClientState state) {
58: super (server, pool, state);
59: }
60:
61: /**
62: * Supplies the ssl session associated with the underlying socket.
63: *
64: * @return the associated ssl session or null
65: */
66: public SSLSession getSession() {
67: // the socket instance is inherited from the super-class
68: if (socket instanceof SSLSocket) {
69: return ((SSLSocket) socket).getSession();
70: }
71: return null;
72: }
73: }
|