Class DigestingEntityConsumer<T>
java.lang.Object
org.apache.hc.core5.http.nio.entity.DigestingEntityConsumer<T>
- All Implemented Interfaces:
AsyncDataConsumer,AsyncEntityConsumer<T>,ResourceHolder
AsyncEntityConsumer decorator that calculates a digest hash from
the data stream content and keeps the list of trailers received with
the data stream.- Since:
- 5.0
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate byte[]private final MessageDigestprivate final AsyncEntityConsumer<T> -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidconsume(ByteBuffer src) Triggered to pass incoming data to the data consumer.voidTriggered to signal a failure in data processing.Returns the result of entity processing when it becomes available ornullif the entity is still being received.byte[]Returns digest hash.List of trailers sent with the data stream.voidvoidTriggered to signal termination of the data stream.voidstreamStart(EntityDetails entityDetails, FutureCallback<T> resultCallback) Signals beginning of an incoming request entity stream.voidupdateCapacity(CapacityChannel capacityChannel) Triggered to signal ability of the underlying data stream to receive data capacity update.
-
Field Details
-
wrapped
-
trailers
-
digester
-
digest
private volatile byte[] digest
-
-
Constructor Details
-
DigestingEntityConsumer
public DigestingEntityConsumer(String algo, AsyncEntityConsumer<T> wrapped) throws NoSuchAlgorithmException - Throws:
NoSuchAlgorithmException
-
-
Method Details
-
streamStart
public void streamStart(EntityDetails entityDetails, FutureCallback<T> resultCallback) throws IOException, HttpException Description copied from interface:AsyncEntityConsumerSignals beginning of an incoming request entity stream.- Specified by:
streamStartin interfaceAsyncEntityConsumer<T>- Parameters:
entityDetails- the details of the incoming message entity.resultCallback- the result callback.- Throws:
IOExceptionHttpException
-
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.- Throws:
HttpExceptionIOException
-
failed
Description copied from interface:AsyncEntityConsumerTriggered to signal a failure in data processing.- Specified by:
failedin interfaceAsyncEntityConsumer<T>- Parameters:
cause- the cause of the failure.
-
getContent
Description copied from interface:AsyncEntityConsumerReturns the result of entity processing when it becomes available ornullif the entity is still being received.- Specified by:
getContentin interfaceAsyncEntityConsumer<T>- Returns:
- the response processing result.
-
releaseResources
public void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-
getTrailers
List of trailers sent with the data stream.- Returns:
- the list of trailers sent with the data stream
-
getDigest
public byte[] getDigest()Returns digest hash.- Returns:
- the digest hash value.
-