Class AbstractBinAsyncEntityProducer
java.lang.Object
org.apache.hc.core5.http.nio.entity.AbstractBinAsyncEntityProducer
- All Implemented Interfaces:
EntityDetails,AsyncDataProducer,AsyncEntityProducer,ResourceHolder
@Contract(threading=SAFE_CONDITIONAL)
public abstract class AbstractBinAsyncEntityProducer
extends Object
implements AsyncEntityProducer
Abstract binary entity content producer.
- Since:
- 5.0
-
Constructor Summary
ConstructorsConstructorDescriptionAbstractBinAsyncEntityProducer(int fragmentSizeHint, ContentType contentType) -
Method Summary
Modifier and TypeMethodDescriptionfinal intReturns the number of bytes immediately available for output.protected abstract intReturns the number of bytes immediately available for output.Gets content encoding of this entity, if known.longGets length of this entity, if known.final StringGets content type of this entity, if known.Gets the preliminary declaration of trailing headers.booleanTests the chunked transfer hint for this entity.final voidproduce(DataStreamChannel channel) Triggered to signal the ability of the underlying data channel to accept more data.protected abstract voidproduceData(StreamChannel<ByteBuffer> channel) Triggered to signal the ability of the underlying byte channel to accept more data.voidMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.hc.core5.http.nio.AsyncEntityProducer
failed, isRepeatable
-
Constructor Details
-
AbstractBinAsyncEntityProducer
-
-
Method Details
-
availableData
protected abstract int availableData()Returns 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.- Returns:
- the number of bytes immediately available for output
-
produceData
Triggered to signal the ability of the underlying byte channel to accept more data. The data producer can choose to write data immediately inside the call or asynchronously at some later point.StreamChannelpassed to this method is threading-safe.- Parameters:
channel- the data channel capable to accepting more data.- Throws:
IOException- in case of an I/O error.
-
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.
-
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.
-
available
public final 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:
-
releaseResources
public void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-