001/** 002 * 003 * Copyright 2015-2019 Florian Schmaus. 004 * 005 * Licensed under the Apache License, Version 2.0 (the "License"); 006 * you may not use this file except in compliance with the License. 007 * You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017package org.jivesoftware.smack.proxy; 018 019import java.io.IOException; 020import java.net.Socket; 021 022public interface ProxySocketConnection { 023 024 /** 025 * Initiate a connection to the given host on the given port. Note that the caller is responsible for closing the 026 * socket in case this method throws. 027 * 028 * @param socket the socket to use to initiate the connection to the proxy. 029 * @param host the host to connect to. 030 * @param port the port to connect to. 031 * @param timeout the timeout in milliseconds. 032 * @throws IOException in case an I/O error occurs. 033 */ 034 void connect(Socket socket, String host, int port, int timeout) 035 throws IOException; 036 037}