Class PathEntityProducer
- java.lang.Object
-
- org.apache.hc.core5.http.nio.entity.PathEntityProducer
-
- All Implemented Interfaces:
EntityDetails,AsyncDataProducer,AsyncEntityProducer,ResourceHolder
public final class PathEntityProducer extends java.lang.Object implements AsyncEntityProducer
AsyncEntityProducerimplementation that generates a data stream from the content at aPath.- Since:
- 5.2
-
-
Field Summary
Fields Modifier and Type Field Description private static intBUFFER_SIZEprivate java.nio.ByteBufferbyteBufferprivate java.util.concurrent.atomic.AtomicReference<java.nio.channels.SeekableByteChannel>channelRefprivate booleanchunkedprivate ContentTypecontentTypeprivate booleaneofprivate java.util.concurrent.atomic.AtomicReference<java.lang.Exception>exceptionprivate java.nio.file.Pathfileprivate longlengthprivate java.nio.file.OpenOption[]openOptions
-
Constructor Summary
Constructors Constructor Description PathEntityProducer(java.nio.file.Path file, int bufferSize, ContentType contentType, boolean chunked, java.nio.file.OpenOption... openOptions)PathEntityProducer(java.nio.file.Path file, java.nio.file.OpenOption... openOptions)PathEntityProducer(java.nio.file.Path file, ContentType contentType, boolean chunked, java.nio.file.OpenOption... openOptions)PathEntityProducer(java.nio.file.Path file, ContentType contentType, java.nio.file.OpenOption... openOptions)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intavailable()Returns the number of bytes immediately available for output.voidfailed(java.lang.Exception cause)Triggered to signal a failure in data generation.java.lang.StringgetContentEncoding()Returns content encoding of the entity, if known.longgetContentLength()Returns length of the entity, if known.java.lang.StringgetContentType()Returns content type of the entity, if known.java.lang.ExceptiongetException()java.util.Set<java.lang.String>getTrailerNames()Preliminary declaration of trailing headers.booleanisChunked()Returns chunked transfer hint for this entity.booleanisRepeatable()Determines whether the producer can consistently produce the same content after invocation ofResourceHolder.releaseResources().voidproduce(DataStreamChannel dataStreamChannel)Triggered to signal the ability of the underlying data channel to accept more data.voidreleaseResources()
-
-
-
Field Detail
-
BUFFER_SIZE
private static final int BUFFER_SIZE
- See Also:
- Constant Field Values
-
file
private final java.nio.file.Path file
-
openOptions
private final java.nio.file.OpenOption[] openOptions
-
byteBuffer
private final java.nio.ByteBuffer byteBuffer
-
length
private final long length
-
contentType
private final ContentType contentType
-
chunked
private final boolean chunked
-
exception
private final java.util.concurrent.atomic.AtomicReference<java.lang.Exception> exception
-
channelRef
private final java.util.concurrent.atomic.AtomicReference<java.nio.channels.SeekableByteChannel> channelRef
-
eof
private boolean eof
-
-
Constructor Detail
-
PathEntityProducer
public PathEntityProducer(java.nio.file.Path file, ContentType contentType, boolean chunked, java.nio.file.OpenOption... openOptions) throws java.io.IOException- Throws:
java.io.IOException
-
PathEntityProducer
public PathEntityProducer(java.nio.file.Path file, ContentType contentType, java.nio.file.OpenOption... openOptions) throws java.io.IOException- Throws:
java.io.IOException
-
PathEntityProducer
public PathEntityProducer(java.nio.file.Path file, int bufferSize, ContentType contentType, boolean chunked, java.nio.file.OpenOption... openOptions) throws java.io.IOException- Throws:
java.io.IOException
-
PathEntityProducer
public PathEntityProducer(java.nio.file.Path file, java.nio.file.OpenOption... openOptions) throws java.io.IOException- Throws:
java.io.IOException
-
-
Method Detail
-
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.- Specified by:
availablein interfaceAsyncDataProducer- Returns:
- the number of bytes immediately available for output
-
failed
public void failed(java.lang.Exception cause)
Description copied from interface:AsyncEntityProducerTriggered to signal a failure in data generation.- Specified by:
failedin interfaceAsyncEntityProducer- Parameters:
cause- the cause of the failure.
-
getContentEncoding
public java.lang.String getContentEncoding()
Description copied from interface:EntityDetailsReturns content encoding of the entity, if known.- Specified by:
getContentEncodingin interfaceEntityDetails
-
getContentLength
public long getContentLength()
Description copied from interface:EntityDetailsReturns length of the entity, if known.- Specified by:
getContentLengthin interfaceEntityDetails
-
getContentType
public java.lang.String getContentType()
Description copied from interface:EntityDetailsReturns content type of the entity, if known.- Specified by:
getContentTypein interfaceEntityDetails
-
getException
public java.lang.Exception getException()
-
getTrailerNames
public java.util.Set<java.lang.String> getTrailerNames()
Description copied from interface:EntityDetailsPreliminary declaration of trailing headers.- Specified by:
getTrailerNamesin interfaceEntityDetails
-
isChunked
public boolean isChunked()
Description copied from interface:EntityDetailsReturns chunked transfer hint for this entity.The behavior of wrapping entities is implementation dependent, but should respect the primary purpose.
- Specified by:
isChunkedin interfaceEntityDetails
-
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
-
produce
public void produce(DataStreamChannel dataStreamChannel) throws java.io.IOException
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.- Specified by:
producein interfaceAsyncDataProducer- Parameters:
dataStreamChannel- the data channel capable to accepting more data.- Throws:
java.io.IOException
-
releaseResources
public void releaseResources()
- Specified by:
releaseResourcesin interfaceResourceHolder
-
-