Class AbstractAsyncPushHandler<T>
- java.lang.Object
-
- org.apache.hc.core5.http.nio.support.AbstractAsyncPushHandler<T>
-
- Type Parameters:
T- response message representation.
- All Implemented Interfaces:
AsyncDataConsumer,AsyncPushConsumer,ResourceHolder
public abstract class AbstractAsyncPushHandler<T> extends java.lang.Object implements AsyncPushConsumer
Abstract push response handler.- Since:
- 5.0
-
-
Field Summary
Fields Modifier and Type Field Description private AsyncResponseConsumer<T>responseConsumer
-
Constructor Summary
Constructors Constructor Description AbstractAsyncPushHandler(AsyncResponseConsumer<T> responseConsumer)
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidconsume(java.nio.ByteBuffer src)Triggered to pass incoming data to the data consumer.voidconsumePromise(HttpRequest promise, HttpResponse response, EntityDetails entityDetails, HttpContext httpContext)Triggered to signal receipt of a request message head used as a promise and the corresponding pushed response.voidfailed(java.lang.Exception cause)Triggered to signal a failure in data processing.protected voidhandleError(HttpRequest promise, java.lang.Exception cause)Triggered to handle the exception thrown while processing a push response.protected abstract voidhandleResponse(HttpRequest promise, T responseMessage)Triggered to handle the push message with the given promised request.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
-
responseConsumer
private final AsyncResponseConsumer<T> responseConsumer
-
-
Constructor Detail
-
AbstractAsyncPushHandler
public AbstractAsyncPushHandler(AsyncResponseConsumer<T> responseConsumer)
-
-
Method Detail
-
handleResponse
protected abstract void handleResponse(HttpRequest promise, T responseMessage) throws java.io.IOException, HttpException
Triggered to handle the push message with the given promised request.- Parameters:
promise- the promised request message.responseMessage- the pushed response message.- Throws:
java.io.IOExceptionHttpException
-
handleError
protected void handleError(HttpRequest promise, java.lang.Exception cause)
Triggered to handle the exception thrown while processing a push response.- Parameters:
promise- the promised request message.cause- the cause of error.
-
consumePromise
public final void consumePromise(HttpRequest promise, HttpResponse response, EntityDetails entityDetails, HttpContext httpContext) throws HttpException, java.io.IOException
Description copied from interface:AsyncPushConsumerTriggered to signal receipt of a request message head used as a promise and the corresponding pushed response.- Specified by:
consumePromisein interfaceAsyncPushConsumer- Parameters:
promise- the request message head used as a promise.response- the pushed response message.entityDetails- the response entity details ornullif the response does not enclose an entity.httpContext- the actual execution context.- Throws:
HttpExceptionjava.io.IOException
-
updateCapacity
public final 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 final 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 final 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
-
failed
public final void failed(java.lang.Exception cause)
Description copied from interface:AsyncPushConsumerTriggered to signal a failure in data processing.- Specified by:
failedin interfaceAsyncPushConsumer- Parameters:
cause- the cause of the failure.
-
releaseResources
public final void releaseResources()
- Specified by:
releaseResourcesin interfaceResourceHolder
-
-