Class AbstractClassicEntityConsumer<T>
- java.lang.Object
-
- org.apache.hc.core5.http.nio.support.classic.AbstractClassicEntityConsumer<T>
-
- Type Parameters:
T- entity representation.
- All Implemented Interfaces:
AsyncDataConsumer,AsyncEntityConsumer<T>,ResourceHolder
public abstract class AbstractClassicEntityConsumer<T> extends java.lang.Object implements AsyncEntityConsumer<T>
AsyncEntityConsumerimplementation that acts as a compatibility layer for classicInputStreambased interfaces. Blocking input processing is executed through anExecutor.- Since:
- 5.0
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private static classAbstractClassicEntityConsumer.State
-
Field Summary
Fields Modifier and Type Field Description private SharedInputBufferbufferprivate java.util.concurrent.atomic.AtomicReference<java.lang.Exception>exceptionRefprivate java.util.concurrent.Executorexecutorprivate java.util.concurrent.atomic.AtomicReference<T>resultRefprivate java.util.concurrent.atomic.AtomicReference<AbstractClassicEntityConsumer.State>state
-
Constructor Summary
Constructors Constructor Description AbstractClassicEntityConsumer(int initialBufferSize, java.util.concurrent.Executor executor)
-
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.protected abstract TconsumeData(ContentType contentType, java.io.InputStream inputStream)Processes entity data from the given stream.voidfailed(java.lang.Exception cause)Triggered to signal a failure in data processing.TgetContent()Returns the result of entity processing when it becomes available ornullif the entity is still being received.java.lang.ExceptiongetException()voidreleaseResources()voidstreamEnd(java.util.List<? extends Header> trailers)Triggered 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 Detail
-
executor
private final java.util.concurrent.Executor executor
-
buffer
private final SharedInputBuffer buffer
-
state
private final java.util.concurrent.atomic.AtomicReference<AbstractClassicEntityConsumer.State> state
-
resultRef
private final java.util.concurrent.atomic.AtomicReference<T> resultRef
-
exceptionRef
private final java.util.concurrent.atomic.AtomicReference<java.lang.Exception> exceptionRef
-
-
Method Detail
-
consumeData
protected abstract T consumeData(ContentType contentType, java.io.InputStream inputStream) throws java.io.IOException
Processes entity data from the given stream.- Parameters:
contentType- the entity content typeinputStream- the input stream- Returns:
- the result of entity processing.
- Throws:
java.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
-
streamStart
public final void streamStart(EntityDetails entityDetails, FutureCallback<T> resultCallback) throws HttpException, java.io.IOException
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:
HttpExceptionjava.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:AsyncEntityConsumerTriggered to signal a failure in data processing.- Specified by:
failedin interfaceAsyncEntityConsumer<T>- Parameters:
cause- the cause of the failure.
-
getException
public final java.lang.Exception getException()
-
getContent
public final T 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
-
-