/** * Logback: the reliable, generic, fast and flexible logging framework. * Copyright (C) 1999-2013, QOS.ch. All rights reserved. * * This program and the accompanying materials are dual-licensed under * either the terms of the Eclipse Public License v1.0 as published by * the Eclipse Foundation * * or (per the licensee's choosing) * * under the terms of the GNU Lesser General Public License version 2.1 * as published by the Free Software Foundation. */ package ch.qos.logback.core.net; import java.net.Socket; import java.util.concurrent.Callable; import javax.net.SocketFactory; /** * A {@link Runnable} that (re)connects a socket. * <p> * An implementation of this interface is responsible for repeatedly * attempting to create a socket connection to a remote host. * * @author Carl Harris */ public interface SocketConnector extends Callable<Socket> { /** * An exception handler that is notified of all exceptions that occur * during the (re)connection process. */ public interface ExceptionHandler { void connectionFailed(SocketConnector connector, Exception ex); } /** * Blocks the calling thread until a connection is successfully * established. * @return the connected socket * @throws InterruptedException the running connection thread was cancelled */ Socket call() throws InterruptedException; /** * Sets the connector's exception handler. * <p> * The handler must be set before the {@link #call()} method is invoked. * @param exceptionHandler the handler to set */ void setExceptionHandler(ExceptionHandler exceptionHandler); /** * Sets the connector's socket factory. * <p> * If no factory is configured that connector will use the platform's * default factory. * * @param socketFactory the factory to set */ void setSocketFactory(SocketFactory socketFactory); }