Class AbstractServerExchangeHandler<T>
java.lang.Object
org.apache.hc.core5.http.nio.support.AbstractServerExchangeHandler<T>
- Type Parameters:
T- the type of request messages.
- All Implemented Interfaces:
AsyncDataConsumer,AsyncDataExchangeHandler,AsyncDataProducer,AsyncServerExchangeHandler,ResourceHolder
- Direct Known Subclasses:
BasicServerExchangeHandler
public abstract class AbstractServerExchangeHandler<T>
extends Object
implements AsyncServerExchangeHandler
Abstract server side message exchange handler.
- Since:
- 5.0
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal intReturns the number of bytes immediately available for output.final voidconsume(ByteBuffer src) Triggered to pass incoming data to the data consumer.final voidTriggered to signal a failure in data processing.protected abstract voidhandle(T requestMessage, AsyncServerRequestHandler.ResponseTrigger responseTrigger, HttpContext context) Triggered to handles the request object produced by theAsyncRequestConsumerreturned from thesupplyConsumer(HttpRequest, EntityDetails, HttpContext)method.protected AsyncResponseProducerhandleError(Exception ex) final voidhandleRequest(HttpRequest request, EntityDetails entityDetails, ResponseChannel responseChannel, HttpContext context) Processes the actual HTTP request.final voidproduce(DataStreamChannel channel) Triggered to signal the ability of the underlying data channel to accept more data.final voidfinal voidTriggered to signal termination of the data stream.protected abstract AsyncRequestConsumer<T>supplyConsumer(HttpRequest request, EntityDetails entityDetails, HttpContext context) Triggered to supply a request consumer to process the incoming request.final voidupdateCapacity(CapacityChannel capacityChannel) Triggered to signal ability of the underlying data stream to receive data capacity update.
-
Constructor Details
-
AbstractServerExchangeHandler
public AbstractServerExchangeHandler()
-
-
Method Details
-
supplyConsumer
protected abstract AsyncRequestConsumer<T> supplyConsumer(HttpRequest request, EntityDetails entityDetails, HttpContext context) throws HttpException Triggered to supply a request consumer to process the incoming request.- Parameters:
request- the request message.entityDetails- the request entity details.context- the actual execution context.- Returns:
- the request consumer.
- Throws:
HttpException- in case of an HTTP protocol violation.
-
handle
protected abstract void handle(T requestMessage, AsyncServerRequestHandler.ResponseTrigger responseTrigger, HttpContext context) throws HttpException, IOException Triggered to handles the request object produced by theAsyncRequestConsumerreturned from thesupplyConsumer(HttpRequest, EntityDetails, HttpContext)method. The handler can choose to send response messages immediately inside the call or asynchronously at some later point.- Parameters:
requestMessage- the request message.responseTrigger- the response trigger.context- the actual execution context.- Throws:
HttpException- in case of an HTTP protocol violation.IOException- in case of an I/O error.
-
handleRequest
public final void handleRequest(HttpRequest request, EntityDetails entityDetails, ResponseChannel responseChannel, HttpContext context) throws HttpException, IOException Description copied from interface:AsyncServerExchangeHandlerProcesses the actual HTTP request. The handler can choose to send response messages immediately inside the call or asynchronously at some later point.- Specified by:
handleRequestin interfaceAsyncServerExchangeHandler- Parameters:
request- the actual request.entityDetails- the request entity details ornullif the request does not enclose an entity.responseChannel- the response channel.context- the actual execution context.- Throws:
HttpException- in case of an HTTP protocol violation.IOException- in case of an I/O error.
-
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- in case of an I/O error.
-
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- in case of an I/O error.
-
streamEnd
Description copied from interface:AsyncDataConsumerTriggered to signal termination of the data stream.- Specified by:
streamEndin interfaceAsyncDataConsumer- Parameters:
trailers- data stream trailers.- Throws:
HttpException- in case of an HTTP protocol violation.IOException- in case of an I/O error.
-
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:
-
handleError
-
failed
Description copied from interface:AsyncDataExchangeHandlerTriggered to signal a failure in data processing.- Specified by:
failedin interfaceAsyncDataExchangeHandler- Parameters:
cause- the cause of the failure.
-
releaseResources
public final void releaseResources()- Specified by:
releaseResourcesin interfaceResourceHolder
-