All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.subgraph.orchid.ExitCircuit Maven / Gradle / Ivy

The newest version!
package com.subgraph.orchid;

import java.util.concurrent.TimeoutException;

import com.subgraph.orchid.data.IPv4Address;
import com.subgraph.orchid.data.exitpolicy.ExitTarget;

public interface ExitCircuit extends Circuit {
	
	/**
	 * Open an exit stream from the final node in this circuit to the 
	 * specified target address and port.
	 * 
	 * @param address The network address of the exit target.
	 * @param port The port of the exit target.
	 * @return The status response returned by trying to open the stream.
	 */
	Stream openExitStream(IPv4Address address, int port, long timeout) throws InterruptedException, TimeoutException, StreamConnectFailedException;
	
	/**
	 * Open an exit stream from the final node in this circuit to the
	 * specified target hostname and port.
	 * 
	 * @param hostname The network hostname of the exit target.
	 * @param port The port of the exit target.
	 * @return The status response returned by trying to open the stream.
	 */
	Stream openExitStream(String hostname, int port, long timeout) throws InterruptedException, TimeoutException, StreamConnectFailedException;
	
	/**
	 * Return true if the final node of this circuit is believed to be able to connect to
	 * the specified ExitTarget.  Returns false if the target destination is
	 * not permitted by the exit policy of the final node in this circuit or if the target
	 * has been previously recorded to have failed through this circuit.
	 * 
	 * @param target The exit destination.
	 * @return Return true if is likely that the final node of this circuit can connect to the specified exit target.
	 */
	boolean canHandleExitTo(ExitTarget target);

	boolean canHandleExitToPort(int port);
	/**
	 * Records the specified ExitTarget as a failed connection so that {@link #canHandleExitTo(ExitTarget)} will
	 * no longer return true for this exit destination.
	 * 
	 * @param target The ExitTarget to which a connection has failed through this circuit.
	 */
	public void recordFailedExitTarget(ExitTarget target);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy