1. /*
  2. * $Header: /home/cvs/jakarta-commons/httpclient/src/java/org/apache/commons/httpclient/protocol/SecureProtocolSocketFactory.java,v 1.6 2004/04/18 23:51:38 jsdever Exp $
  3. * $Revision: 1.6 $
  4. * $Date: 2004/04/18 23:51:38 $
  5. *
  6. * ====================================================================
  7. *
  8. * Copyright 2002-2004 The Apache Software Foundation
  9. *
  10. * Licensed under the Apache License, Version 2.0 (the "License");
  11. * you may not use this file except in compliance with the License.
  12. * You may obtain a copy of the License at
  13. *
  14. * http://www.apache.org/licenses/LICENSE-2.0
  15. *
  16. * Unless required by applicable law or agreed to in writing, software
  17. * distributed under the License is distributed on an "AS IS" BASIS,
  18. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  19. * See the License for the specific language governing permissions and
  20. * limitations under the License.
  21. * ====================================================================
  22. *
  23. * This software consists of voluntary contributions made by many
  24. * individuals on behalf of the Apache Software Foundation. For more
  25. * information on the Apache Software Foundation, please see
  26. * <http://www.apache.org/>.
  27. *
  28. */
  29. package org.apache.commons.httpclient.protocol;
  30. import java.io.IOException;
  31. import java.net.Socket;
  32. import java.net.UnknownHostException;
  33. /**
  34. * A ProtocolSocketFactory that is secure.
  35. *
  36. * @see org.apache.commons.httpclient.protocol.ProtocolSocketFactory
  37. *
  38. * @author Michael Becke
  39. * @author <a href="mailto:mbowler@GargoyleSoftware.com">Mike Bowler</a>
  40. * @since 2.0
  41. */
  42. public interface SecureProtocolSocketFactory extends ProtocolSocketFactory {
  43. /**
  44. * Returns a socket connected to the given host that is layered over an
  45. * existing socket. Used primarily for creating secure sockets through
  46. * proxies.
  47. *
  48. * @param socket the existing socket
  49. * @param host the host name/IP
  50. * @param port the port on the host
  51. * @param autoClose a flag for closing the underling socket when the created
  52. * socket is closed
  53. *
  54. * @return Socket a new socket
  55. *
  56. * @throws IOException if an I/O error occurs while creating the socket
  57. * @throws UnknownHostException if the IP address of the host cannot be
  58. * determined
  59. */
  60. Socket createSocket(
  61. Socket socket,
  62. String host,
  63. int port,
  64. boolean autoClose
  65. ) throws IOException, UnknownHostException;
  66. }