Package org.apache.hc.core5.reactive
Class ReactiveResponseConsumer
java.lang.Object
org.apache.hc.core5.reactive.ReactiveResponseConsumer
- All Implemented Interfaces:
AsyncDataConsumer,AsyncResponseConsumer<Void>,ResourceHolder
@Contract(threading=SAFE)
public final class ReactiveResponseConsumer
extends Object
implements AsyncResponseConsumer<Void>
An
AsyncResponseConsumer that publishes the response body through
a Publisher, as defined by the Reactive Streams specification. The
response is represented as a Message consisting of a HttpResponse representing the headers and a Publisher representing
the response body as an asynchronous stream of ByteBuffer instances.- Since:
- 5.0
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate EntityDetailsprivate HttpResponseprivate final ReactiveDataConsumerprivate BasicFuture<Void> private final BasicFuture<Message<HttpResponse, org.reactivestreams.Publisher<ByteBuffer>>> -
Constructor Summary
ConstructorsConstructorDescriptionCreates aReactiveResponseConsumer.ReactiveResponseConsumer(FutureCallback<Message<HttpResponse, org.reactivestreams.Publisher<ByteBuffer>>> responseCallback) Creates aReactiveResponseConsumerthat will call back the suppliedFutureCallbackwith a streamable response. -
Method Summary
Modifier and TypeMethodDescriptionvoidconsume(ByteBuffer src) Triggered to pass incoming data to the data consumer.voidconsumeResponse(HttpResponse response, EntityDetails entityDetails, HttpContext httpContext, FutureCallback<Void> resultCallback) Triggered to signal receipt of a response message head.voidTriggered to signal a failure in data processing.Returns the response entity details.Returns the intermediate (1xx) HTTP response if one was received.Future<Message<HttpResponse, org.reactivestreams.Publisher<ByteBuffer>>> Returns the trailers received at the end of the response.voidinformationResponse(HttpResponse response, HttpContext httpContext) Triggered to signal receipt of an intermediate (1xx) HTTP response.voidvoidTriggered 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 Details
-
reactiveDataConsumer
-
trailers
-
responseFuture
private final BasicFuture<Message<HttpResponse,org.reactivestreams.Publisher<ByteBuffer>>> responseFuture -
responseCompletion
-
informationResponse
-
entityDetails
-
-
Constructor Details
-
ReactiveResponseConsumer
public ReactiveResponseConsumer()Creates aReactiveResponseConsumer. -
ReactiveResponseConsumer
public ReactiveResponseConsumer(FutureCallback<Message<HttpResponse, org.reactivestreams.Publisher<ByteBuffer>>> responseCallback) Creates aReactiveResponseConsumerthat will call back the suppliedFutureCallbackwith a streamable response.- Parameters:
responseCallback- the callback to invoke when the response is available for consumption.
-
-
Method Details
-
getResponseFuture
-
getInformationResponse
Returns the intermediate (1xx) HTTP response if one was received.- Returns:
- the information response, or
nullif none.
-
getEntityDetails
Returns the response entity details.- Returns:
- the entity details, or
nullif none.
-
getTrailers
Returns the trailers received at the end of the response.- Returns:
- a non-null list of zero or more trailers.
-
consumeResponse
public void consumeResponse(HttpResponse response, EntityDetails entityDetails, HttpContext httpContext, FutureCallback<Void> resultCallback) Description copied from interface:AsyncResponseConsumerTriggered to signal receipt of a response message head.- Specified by:
consumeResponsein interfaceAsyncResponseConsumer<Void>- Parameters:
response- the response message head.entityDetails- the response entity details ornullif the response does not enclose an entity.httpContext- the actual execution context.resultCallback- the result callback called when response processing has been completed successfully or unsuccessfully.
-
informationResponse
Description copied from interface:AsyncResponseConsumerTriggered to signal receipt of an intermediate (1xx) HTTP response.- Specified by:
informationResponsein interfaceAsyncResponseConsumer<Void>- Parameters:
response- the intermediate (1xx) HTTP response.httpContext- the actual execution context.
-
failed
Description copied from interface:AsyncResponseConsumerTriggered to signal a failure in data processing.- Specified by:
failedin interfaceAsyncResponseConsumer<Void>- Parameters:
cause- the cause of the failure.
-
updateCapacity
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:
IOException
-
consume
Description 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:
IOException
-
streamEnd
Description copied from interface:AsyncDataConsumerTriggered to signal termination of the data stream.- Specified by:
streamEndin interfaceAsyncDataConsumer- Parameters:
trailers- data stream trailers.
-
releaseResources
public void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-