Class AbstractEndPoint
- All Implemented Interfaces:
- Closeable, AutoCloseable, EndPoint
- Direct Known Subclasses:
- ByteArrayEndPoint, QuicStreamEndPoint, SelectableChannelEndPoint, SslConnection.SslEndPoint
Partial implementation of EndPoint that uses FillInterest and WriteFlusher.
- 
Nested Class SummaryNested classes/interfaces inherited from interface EndPointEndPoint.Pipe, EndPoint.SslSessionData, EndPoint.Wrapper
- 
Field Summary
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionfinal voidclose()Closes any backing stream associated with the endpoint.final voidCloses any backing stream associated with the endpoint, passing a possiblynullfailure cause.protected voiddoClose()protected voidprotected voidvoidfillInterested(Callback callback) Requests callback methods to be invoked when a call toEndPoint.fill(ByteBuffer)would return data or EOF.longabstract SocketAddressabstract SocketAddressbooleanbooleanTests if the input is shutdown.booleanisOpen()This abstract method should be called to check if idle timeouts should still be checked.booleanTests if output is shutdown.protected abstract voidfinal voidonClose()voidCallback method invoked when thisEndPointis closed.protected voidonIdleExpired(TimeoutException timeout) This abstract method is called when the idle timeout has expired.protected abstract voidvoidonOpen()Callback method invoked when this EndPoint is opened.protected voidreset()voidsetConnection(Connection connection) protected final voidfinal voidShuts down the output.toString()booleantryFillInterested(Callback callback) Requests callback methods to be invoked when a call toEndPoint.fill(ByteBuffer)would return data or EOF.voidupgrade(Connection newConnection) Upgrades this EndPoint from the current connection to the given new connection.voidwrite(Callback callback, ByteBuffer... buffers) Writes the given buffers viaEndPoint.flush(ByteBuffer...)and invokes callback methods when either all the data has been flushed or an error occurs.Methods inherited from class IdleTimeoutcheckIdleTimeout, getIdleFor, getIdleTimeout, getScheduler, notIdle, setIdleTimeoutMethods inherited from class Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface EndPointfill, flush, getIdleTimeout, getSslSessionData, getTransport, isSecure, receive, send, setIdleTimeout, write
- 
Constructor Details- 
AbstractEndPoint
 
- 
- 
Method Details- 
getLocalAddress- Specified by:
- getLocalAddressin interface- EndPoint
- Returns:
- The local InetSocketAddress to which this EndPointis bound, ornullif thisEndPointis not bound to a Socket address.
 
- 
getLocalSocketAddress- Specified by:
- getLocalSocketAddressin interface- EndPoint
- Returns:
- the local SocketAddress to which this EndPointis bound ornullif thisEndPointis not bound to a Socket address.
 
- 
getRemoteAddress- Specified by:
- getRemoteAddressin interface- EndPoint
- Returns:
- The remote InetSocketAddress to which this EndPointis connected, ornullif thisEndPointis not connected to a Socket address.
 
- 
getRemoteSocketAddress- Specified by:
- getRemoteSocketAddressin interface- EndPoint
- Returns:
- The remote SocketAddress to which this EndPointis connected, ornullif thisEndPointis not connected to a Socket address.
 
- 
shutdownInputprotected final void shutdownInput()
- 
shutdownOutputpublic final void shutdownOutput()Description copied from interface:EndPointShuts down the output. This call indicates that no more data will be sent from this endpoint and that the remote endpoint should read an EOF once all previously sent data has been read. Shutdown may be done either at the TCP/IP level, as a protocol exchange (for example, TLS close handshake) or both. If the endpoint has EndPoint.isInputShutdown()true, then this call has the same effect asEndPoint.close().- Specified by:
- shutdownOutputin interface- EndPoint
 
- 
close
- 
close
- 
doShutdownInputprotected void doShutdownInput()
- 
doShutdownOutputprotected void doShutdownOutput()
- 
doCloseprotected void doClose()
- 
isOutputShutdownpublic boolean isOutputShutdown()Description copied from interface:EndPointTests if output is shutdown. The output is shutdown by a call to EndPoint.shutdownOutput()orEndPoint.close().- Specified by:
- isOutputShutdownin interface- EndPoint
- Returns:
- true if the output is shutdown or the endpoint is closed.
 
- 
isInputShutdownpublic boolean isInputShutdown()Description copied from interface:EndPointTests if the input is shutdown. The input is shutdown if an EOF has been read while doing a EndPoint.fill(ByteBuffer). Once the input is shutdown, all calls toEndPoint.fill(ByteBuffer)will return -1, until such time as the end point is close, when they will returnEofException.- Specified by:
- isInputShutdownin interface- EndPoint
- Returns:
- true if the input is shutdown or the endpoint is closed.
 
- 
isOpenpublic boolean isOpen()Description copied from class:IdleTimeoutThis abstract method should be called to check if idle timeouts should still be checked.- Specified by:
- isOpenin interface- EndPoint
- Specified by:
- isOpenin class- IdleTimeout
- Returns:
- True if the entity monitored should still be checked for idle timeouts
 
- 
getCreatedTimeStamppublic long getCreatedTimeStamp()- Specified by:
- getCreatedTimeStampin interface- EndPoint
- Returns:
- the epoch time in milliseconds when this EndPoint was created
 
- 
getConnection- Specified by:
- getConnectionin interface- EndPoint
- Returns:
- the Connectionassociated with this EndPoint
- See Also:
 
- 
setConnection- Specified by:
- setConnectionin interface- EndPoint
- Parameters:
- connection- the- Connectionassociated with this EndPoint
- See Also:
 
- 
resetprotected void reset()
- 
onOpenpublic void onOpen()Description copied from interface:EndPointCallback method invoked when this EndPoint is opened. - Specified by:
- onOpenin interface- EndPoint
- Overrides:
- onOpenin class- IdleTimeout
- See Also:
 
- 
onClosepublic final void onClose()- Overrides:
- onClosein class- IdleTimeout
 
- 
onClose
- 
fillInterestedDescription copied from interface:EndPointRequests callback methods to be invoked when a call to EndPoint.fill(ByteBuffer)would return data or EOF.- Specified by:
- fillInterestedin interface- EndPoint
- Parameters:
- callback- the callback to call when an error occurs or we are readable. The callback may implement the- Invocableinterface to self declare its blocking status. Non-blocking callbacks may be called more efficiently without dispatch delays.
 
- 
tryFillInterestedDescription copied from interface:EndPointRequests callback methods to be invoked when a call to EndPoint.fill(ByteBuffer)would return data or EOF.- Specified by:
- tryFillInterestedin interface- EndPoint
- Parameters:
- callback- the callback to call when an error occurs or we are readable. The callback may implement the- Invocableinterface to self declare its blocking status. Non-blocking callbacks may be called more efficiently without dispatch delays.
- Returns:
- true if set
 
- 
isFillInterestedpublic boolean isFillInterested()- Specified by:
- isFillInterestedin interface- EndPoint
- Returns:
- whether EndPoint.fillInterested(Callback)has been called, butEndPoint.fill(ByteBuffer)has not yet been called
 
- 
writeDescription copied from interface:EndPointWrites the given buffers via EndPoint.flush(ByteBuffer...)and invokes callback methods when either all the data has been flushed or an error occurs.- Specified by:
- writein interface- EndPoint
- Parameters:
- callback- the callback to call when an error occurs or the write completed. The callback may implement the- Invocableinterface to self declare its blocking status. Non-blocking callbacks may be called more efficiently without dispatch delays.
- buffers- one or more- ByteBuffers that will be flushed.
- Throws:
- WritePendingException- if another write operation is concurrent.
 
- 
onIncompleteFlushprotected abstract void onIncompleteFlush()
- 
needsFillInterest- Throws:
- IOException
 
- 
getFillInterest
- 
getWriteFlusher
- 
onIdleExpiredDescription copied from class:IdleTimeoutThis abstract method is called when the idle timeout has expired.- Specified by:
- onIdleExpiredin class- IdleTimeout
- Parameters:
- timeout- a TimeoutException
 
- 
upgradeDescription copied from interface:EndPointUpgrades this EndPoint from the current connection to the given new connection. Closes the current connection, links this EndPoint to the new connection and then opens the new connection. If the current connection is an instance of Connection.UpgradeFromthen a buffer of unconsumed bytes is requested. If the buffer of unconsumed bytes is non-null and non-empty, then the new connection is tested: if it is an instance ofConnection.UpgradeTo, then the unconsumed buffer is passed to the new connection; otherwise, an exception is thrown since there are unconsumed bytes that cannot be consumed by the new connection.
- 
toString
- 
toEndPointString
- 
toConnectionString
 
-