Interface Transport
- 
- All Known Implementing Classes:
- TcpTransport,- WebSocketTransport
 
 public interface TransportBase class for all QpidJMS Transport instances.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description voidawaitConnect()Waits interruptibly for theTransportto connect to the remote that was indicated in theconnect(String, int, TransportListener)call.voidclose()Close the Transport, no additional send operations are accepted.Transportconnect(java.lang.String host, int port, TransportListener listener)Performs the connect operation for the implemented Transport type such as a TCP socket connection, SSL/TLS handshake etc.Transportflush()Request a flush of all pending writes to the underlying connection.ProtonBufferAllocatorgetBufferAllocator()Gets a buffer allocator that can produceProtonBufferinstance that may be optimized for use with the underlying transport implementation.java.lang.StringgetHost()java.security.PrincipalgetLocalPrincipal()intgetPort()java.net.URIgetRemoteURI()Returns a URI that contains some meaningful information about the remote connection such as a scheme that reflects the transport type and the remote host and port that the connection was instructed to connect to.SslOptionsgetSslOptions()TransportListenergetTransportListener()Gets the currently set TransportListener instanceTransportOptionsgetTransportOptions()booleanisConnected()booleanisSecure()Transportwrite(ProtonBuffer output)Writes a chunk of data over the Transport connection without performing an explicit flush on the transport.Transportwrite(ProtonBuffer output, java.lang.Runnable ioComplete)Writes a chunk of data over the Transport connection without performing an explicit flush on the transport.TransportwriteAndFlush(ProtonBuffer output)Writes a chunk of data over the Transport connection and requests a flush of all pending queued write operationsTransportwriteAndFlush(ProtonBuffer output, java.lang.Runnable ioComplete)Writes a chunk of data over the Transport connection and requests a flush of all pending queued write operations
 
- 
- 
- 
Method Detail- 
connectTransport connect(java.lang.String host, int port, TransportListener listener) throws java.io.IOException Performs the connect operation for the implemented Transport type such as a TCP socket connection, SSL/TLS handshake etc. The connection operation itself will be performed as an asynchronous operation with the success or failure being communicated to the event pointTransportListener.transportError(Throwable). If the users wishes to perform a block on connect outcome theawaitConnect()method will wait for and or throw an error based on the connect outcome.- Parameters:
- host- The remote host that this- Transportshould attempt to connect to.
- port- The port on the remote host that this- Transportshould attempt to bind to.
- listener- The- TransportListenerthat will handle- Transportevents.
- Returns:
- this Transportinstance.
- Throws:
- java.io.IOException- if an error occurs while attempting the connect.
 
 - 
awaitConnectvoid awaitConnect() throws java.lang.InterruptedException, java.io.IOExceptionWaits interruptibly for theTransportto connect to the remote that was indicated in theconnect(String, int, TransportListener)call.- Throws:
- java.lang.InterruptedException- If the wait mechanism was interrupted while waiting for a successful connect.
- java.io.IOException- If the- Transportfailed to connect or was closed before connected.
 
 - 
isConnectedboolean isConnected() - Returns:
- true if transport is connected or false if the connection is down.
 
 - 
isSecureboolean isSecure() - Returns:
- true if transport is connected using a secured channel (SSL).
 
 - 
closevoid close() throws java.io.IOExceptionClose the Transport, no additional send operations are accepted.- Throws:
- java.io.IOException- if an error occurs while closing the connection.
 
 - 
getBufferAllocatorProtonBufferAllocator getBufferAllocator() Gets a buffer allocator that can produceProtonBufferinstance that may be optimized for use with the underlying transport implementation.- Returns:
- a ProtonBufferAllocatorthat creates transport friendly buffers.
 
 - 
writeTransport write(ProtonBuffer output) throws java.io.IOException Writes a chunk of data over the Transport connection without performing an explicit flush on the transport.- Parameters:
- output- The buffer of data that is to be transmitted.
- Returns:
- this Transportinstance.
- Throws:
- java.io.IOException- if an error occurs during the write operation.
 
 - 
writeTransport write(ProtonBuffer output, java.lang.Runnable ioComplete) throws java.io.IOException Writes a chunk of data over the Transport connection without performing an explicit flush on the transport. This method allows for a completion callback that is signaled when the actual low level IO operation is completed which could be after this method has returned.- Parameters:
- output- The buffer of data that is to be transmitted.
- ioComplete- A- Runnablethat is invoked when the IO operation completes successfully.
- Returns:
- this Transportinstance.
- Throws:
- java.io.IOException- if an error occurs during the write operation.
 
 - 
writeAndFlushTransport writeAndFlush(ProtonBuffer output) throws java.io.IOException Writes a chunk of data over the Transport connection and requests a flush of all pending queued write operations- Parameters:
- output- The buffer of data that is to be transmitted.
- Returns:
- this Transportinstance.
- Throws:
- java.io.IOException- if an error occurs during the write operation.
 
 - 
writeAndFlushTransport writeAndFlush(ProtonBuffer output, java.lang.Runnable ioComplete) throws java.io.IOException Writes a chunk of data over the Transport connection and requests a flush of all pending queued write operations- Parameters:
- output- The buffer of data that is to be transmitted.
- ioComplete- A- Runnablethat is invoked when the IO operation completes successfully.
- Returns:
- this Transportinstance.
- Throws:
- java.io.IOException- if an error occurs during the write operation.
 
 - 
flushTransport flush() throws java.io.IOException Request a flush of all pending writes to the underlying connection.- Returns:
- this Transportinstance.
- Throws:
- java.io.IOException- if an error occurs during the flush operation.
 
 - 
getTransportListenerTransportListener getTransportListener() Gets the currently set TransportListener instance- Returns:
- the current TransportListener or null if none set.
 
 - 
getTransportOptionsTransportOptions getTransportOptions() - Returns:
- a TransportOptionsinstance copied from the immutable options given at create time..
 
 - 
getSslOptionsSslOptions getSslOptions() - Returns:
- a SslOptionsinstance copied from the immutable options given at create time..
 
 - 
getHostjava.lang.String getHost() - Returns:
- the host name or IP address that the transport connects to.
 
 - 
getPortint getPort() - Returns:
- the port that the transport connects to.
 
 - 
getRemoteURIjava.net.URI getRemoteURI() Returns a URI that contains some meaningful information about the remote connection such as a scheme that reflects the transport type and the remote host and port that the connection was instructed to connect to. If called before theconnect(String, int, TransportListener)method this method returnsnull.- Returns:
- a URI that reflects a meaningful view of the Transportremote connection details.
 
 - 
getLocalPrincipaljava.security.Principal getLocalPrincipal() - Returns:
- the local principal for a Transport that is using a secure connection.
 
 
- 
 
-