Class BasicClientExchangeHandler<T>

    • Field Detail

      • completed

        private final java.util.concurrent.atomic.AtomicBoolean completed
      • outputTerminated

        private final java.util.concurrent.atomic.AtomicBoolean outputTerminated
    • Method Detail

      • produceRequest

        public void produceRequest​(RequestChannel requestChannel,
                                   HttpContext httpContext)
                            throws HttpException,
                                   java.io.IOException
        Description copied from interface: AsyncClientExchangeHandler
        Triggered to signal the ability of the underlying request channel to accept a request messages. The data producer can choose to send a request message immediately inside the call or asynchronously at some later point.
        Specified by:
        produceRequest in interface AsyncClientExchangeHandler
        Parameters:
        requestChannel - the request channel capable to accepting a request message.
        httpContext - the actual execution context.
        Throws:
        HttpException
        java.io.IOException
      • available

        public int available()
        Description copied from interface: AsyncDataProducer
        Returns the number of bytes immediately available for output. This method can be used as a hint to control output events of the underlying I/O session.
        Specified by:
        available in interface AsyncDataProducer
        Returns:
        the number of bytes immediately available for output
      • produce

        public void produce​(DataStreamChannel channel)
                     throws java.io.IOException
        Description copied from interface: AsyncDataProducer
        Triggered to signal the ability of the underlying data channel to accept more data. The data producer can choose to write data immediately inside the call or asynchronously at some later point.
        Specified by:
        produce in interface AsyncDataProducer
        Parameters:
        channel - the data channel capable to accepting more data.
        Throws:
        java.io.IOException
      • updateCapacity

        public void updateCapacity​(CapacityChannel capacityChannel)
                            throws java.io.IOException
        Description copied from interface: AsyncDataConsumer
        Triggered to signal ability of the underlying data stream to receive data capacity update. The data consumer can choose to write data immediately inside the call or asynchronously at some later point.
        Specified by:
        updateCapacity in interface AsyncDataConsumer
        Parameters:
        capacityChannel - the channel for capacity updates.
        Throws:
        java.io.IOException
      • consume

        public void consume​(java.nio.ByteBuffer src)
                     throws java.io.IOException
        Description copied from interface: AsyncDataConsumer
        Triggered to pass incoming data to the data consumer. The consumer must consume the entire content of the data buffer. The consumer must stop incrementing its capacity on the capacity channel if it is unable to accept more data. Once the data consumer has handled accumulated data or allocated more intermediate storage it can update its capacity information on the capacity channel.
        Specified by:
        consume in interface AsyncDataConsumer
        Parameters:
        src - data source.
        Throws:
        java.io.IOException
      • failed

        public void failed​(java.lang.Exception cause)
        Description copied from interface: AsyncDataExchangeHandler
        Triggered to signal a failure in data processing.
        Specified by:
        failed in interface AsyncDataExchangeHandler
        Parameters:
        cause - the cause of the failure.
      • internalReleaseResources

        private void internalReleaseResources()