From c78f7920a254ff4d9f81116359d9189fdac60514 Mon Sep 17 00:00:00 2001 From: Oleg Kalnichevski Date: Fri, 29 Sep 2006 19:58:24 +0000 Subject: [PATCH] [HTTPCORE-14] Consider decoupling HttpHost and Scheme and moving Scheme, SocketFactory and SecureSocketFactory to HttpConn Changelog: ---------- * Moved Scheme, SocketFactory, SecureSocketFactory and related classes to HttpConn git-svn-id: https://svn.apache.org/repos/asf/jakarta/httpcomponents/httpclient/trunk@451408 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/http/conn/SecureSocketFactory.java | 70 +++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 src/java/org/apache/http/conn/SecureSocketFactory.java diff --git a/src/java/org/apache/http/conn/SecureSocketFactory.java b/src/java/org/apache/http/conn/SecureSocketFactory.java new file mode 100644 index 000000000..d3a22e664 --- /dev/null +++ b/src/java/org/apache/http/conn/SecureSocketFactory.java @@ -0,0 +1,70 @@ +/* + * $HeadURL$ + * $Revision$ + * $Date$ + * + * ==================================================================== + * + * Copyright 2002-2004 The Apache Software Foundation + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * ==================================================================== + * + * This software consists of voluntary contributions made by many + * individuals on behalf of the Apache Software Foundation. For more + * information on the Apache Software Foundation, please see + * . + * + */ + +package org.apache.http.io; + +import java.io.IOException; +import java.net.Socket; +import java.net.UnknownHostException; + +/** + * A {@link SocketFactory SocketFactory} for secure sockets (SSL/TLS). + * See there for things to consider when implementing a socket factory. + * + * @author Michael Becke + * @author Mike Bowler + * @since 2.0 + */ +public interface SecureSocketFactory extends SocketFactory { + + /** + * Returns a socket connected to the given host that is layered over an + * existing socket. Used primarily for creating secure sockets through + * proxies. + * + * @param socket the existing socket + * @param host the host name/IP + * @param port the port on the host + * @param autoClose a flag for closing the underling socket when the created + * socket is closed + * + * @return Socket a new socket + * + * @throws IOException if an I/O error occurs while creating the socket + * @throws UnknownHostException if the IP address of the host cannot be + * determined + */ + Socket createSocket( + Socket socket, + String host, + int port, + boolean autoClose + ) throws IOException, UnknownHostException; + +}