Class DigestingEntityProducer
java.lang.Object
org.apache.hc.core5.http.nio.entity.DigestingEntityProducer
- All Implemented Interfaces:
EntityDetails,AsyncDataProducer,AsyncEntityProducer,ResourceHolder
AsyncEntityProducer decorator that calculates a digest hash from
the data stream content and appends its value to the list of trailers.- Since:
- 5.0
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionintReturns the number of bytes immediately available for output.voidTriggered to signal a failure in data generation.Gets content encoding of this entity, if known.longGets length of this entity, if known.Gets content type of this entity, if known.byte[]Returns digest hash.Gets the preliminary declaration of trailing headers.booleanTests the chunked transfer hint for this entity.booleanDetermines whether the producer can consistently produce the same content after invocation ofResourceHolder.releaseResources().voidproduce(DataStreamChannel channel) Triggered to signal the ability of the underlying data channel to accept more data.void
-
Constructor Details
-
DigestingEntityProducer
-
-
Method Details
-
isRepeatable
public boolean isRepeatable()Description copied from interface:AsyncEntityProducerDetermines whether the producer can consistently produce the same content after invocation ofResourceHolder.releaseResources().- Specified by:
isRepeatablein interfaceAsyncEntityProducer
-
getContentLength
public long getContentLength()Description copied from interface:EntityDetailsGets length of this entity, if known.- Specified by:
getContentLengthin interfaceEntityDetails- Returns:
- the length of this entity, may be
0.
-
getContentType
Description copied from interface:EntityDetailsGets content type of this entity, if known.- Specified by:
getContentTypein interfaceEntityDetails- Returns:
- the content type of this entity, may be
null.
-
getContentEncoding
Description copied from interface:EntityDetailsGets content encoding of this entity, if known.- Specified by:
getContentEncodingin interfaceEntityDetails- Returns:
- the content encoding of this entity, may be
null.
-
isChunked
public boolean isChunked()Description copied from interface:EntityDetailsTests the chunked transfer hint for this entity.The behavior of wrapping entities is implementation dependent, but should respect the primary purpose.
- Specified by:
isChunkedin interfaceEntityDetails- Returns:
- the chunked transfer hint for this entity.
-
getTrailerNames
Description copied from interface:EntityDetailsGets the preliminary declaration of trailing headers.- Specified by:
getTrailerNamesin interfaceEntityDetails- Returns:
- the preliminary declaration of trailing headers.
-
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.Please note this method should return zero if the data producer is unable to produce any more data, in which case
AsyncDataProducer.produce(DataStreamChannel)method will not get triggered. The producer can resume writing out data asynchronously once more data becomes available or request output readiness events withDataStreamChannel.requestOutput().- Specified by:
availablein interfaceAsyncDataProducer- Returns:
- the number of bytes immediately available for output
- See Also:
-
produce
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.Please note this method gets triggered only if
AsyncDataProducer.available()returns a positive value.- Specified by:
producein interfaceAsyncDataProducer- Parameters:
channel- the data channel capable of accepting more data.- Throws:
IOException- in case of an I/O error.- See Also:
-
failed
Description copied from interface:AsyncEntityProducerTriggered to signal a failure in data generation.- Specified by:
failedin interfaceAsyncEntityProducer- Parameters:
cause- the cause of the failure.
-
releaseResources
public void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-
getDigest
public byte[] getDigest()Returns digest hash.- Returns:
- the digest hash value.
-