Package org.apache.hc.core5.reactive
Class ReactiveServerExchangeHandler
- java.lang.Object
-
- org.apache.hc.core5.reactive.ReactiveServerExchangeHandler
-
- All Implemented Interfaces:
AsyncDataConsumer,AsyncDataExchangeHandler,AsyncDataProducer,AsyncServerExchangeHandler,ResourceHolder
public final class ReactiveServerExchangeHandler extends java.lang.Object implements AsyncServerExchangeHandler
An implementation ofAsyncServerExchangeHandlerdesigned to work with reactive streams.- Since:
- 5.0
-
-
Field Summary
Fields Modifier and Type Field Description private DataStreamChannelchannelprivate ReactiveDataConsumerrequestConsumerprivate ReactiveRequestProcessorrequestProcessorprivate java.util.concurrent.atomic.AtomicReference<ReactiveDataProducer>responseProducer
-
Constructor Summary
Constructors Constructor Description ReactiveServerExchangeHandler(ReactiveRequestProcessor requestProcessor)Creates aReactiveServerExchangeHandler.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intavailable()Returns the number of bytes immediately available for output.voidconsume(java.nio.ByteBuffer src)Triggered to pass incoming data to the data consumer.voidfailed(java.lang.Exception cause)Triggered to signal a failure in data processing.voidhandleRequest(HttpRequest request, EntityDetails entityDetails, ResponseChannel responseChannel, HttpContext context)Processes the actual HTTP request.voidproduce(DataStreamChannel channel)Triggered to signal the ability of the underlying data channel to accept more data.voidreleaseResources()voidstreamEnd(java.util.List<? extends Header> trailers)Triggered to signal termination of the data stream.voidupdateCapacity(CapacityChannel capacityChannel)Triggered to signal ability of the underlying data stream to receive data capacity update.
-
-
-
Field Detail
-
requestProcessor
private final ReactiveRequestProcessor requestProcessor
-
responseProducer
private final java.util.concurrent.atomic.AtomicReference<ReactiveDataProducer> responseProducer
-
requestConsumer
private final ReactiveDataConsumer requestConsumer
-
channel
private volatile DataStreamChannel channel
-
-
Constructor Detail
-
ReactiveServerExchangeHandler
public ReactiveServerExchangeHandler(ReactiveRequestProcessor requestProcessor)
Creates aReactiveServerExchangeHandler.- Parameters:
requestProcessor- theReactiveRequestProcessorinstance to invoke when the request is ready to be handled.
-
-
Method Detail
-
handleRequest
public void handleRequest(HttpRequest request, EntityDetails entityDetails, ResponseChannel responseChannel, HttpContext context) throws HttpException, java.io.IOException
Description copied from interface:AsyncServerExchangeHandlerProcesses the actual HTTP request. The handler can choose to send response messages immediately inside the call or asynchronously at some later point.- Specified by:
handleRequestin interfaceAsyncServerExchangeHandler- Parameters:
request- the actual request.entityDetails- the request entity details ornullif the request does not enclose an entity.responseChannel- the response channel.context- the actual execution context.- Throws:
HttpExceptionjava.io.IOException
-
failed
public void failed(java.lang.Exception cause)
Description copied from interface:AsyncDataExchangeHandlerTriggered to signal a failure in data processing.- Specified by:
failedin interfaceAsyncDataExchangeHandler- Parameters:
cause- the cause of the failure.
-
updateCapacity
public void updateCapacity(CapacityChannel capacityChannel) throws java.io.IOException
Description copied from interface:AsyncDataConsumerTriggered 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:
updateCapacityin interfaceAsyncDataConsumer- Parameters:
capacityChannel- the channel for capacity updates.- Throws:
java.io.IOException
-
consume
public void consume(java.nio.ByteBuffer src) throws java.io.IOExceptionDescription copied from interface:AsyncDataConsumerTriggered 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:
consumein interfaceAsyncDataConsumer- Parameters:
src- data source.- Throws:
java.io.IOException
-
streamEnd
public void streamEnd(java.util.List<? extends Header> trailers) throws HttpException, java.io.IOException
Description copied from interface:AsyncDataConsumerTriggered to signal termination of the data stream.- Specified by:
streamEndin interfaceAsyncDataConsumer- Parameters:
trailers- data stream trailers.- Throws:
HttpExceptionjava.io.IOException
-
available
public int available()
Description copied from interface:AsyncDataProducerReturns 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:
availablein interfaceAsyncDataProducer- Returns:
- the number of bytes immediately available for output
-
produce
public void produce(DataStreamChannel channel) throws java.io.IOException
Description copied from interface:AsyncDataProducerTriggered 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:
producein interfaceAsyncDataProducer- Parameters:
channel- the data channel capable to accepting more data.- Throws:
java.io.IOException
-
releaseResources
public void releaseResources()
- Specified by:
releaseResourcesin interfaceResourceHolder
-
-