Package org.eclipse.jetty.client.util
Class FutureResponseListener
- java.lang.Object
-
- org.eclipse.jetty.client.api.Response.Listener.Adapter
-
- org.eclipse.jetty.client.util.BufferingResponseListener
-
- org.eclipse.jetty.client.util.FutureResponseListener
-
- All Implemented Interfaces:
Future<ContentResponse>,EventListener,Response.AsyncContentListener,Response.BeginListener,Response.CompleteListener,Response.ContentListener,Response.FailureListener,Response.HeaderListener,Response.HeadersListener,Response.Listener,Response.ResponseListener,Response.SuccessListener
public class FutureResponseListener extends BufferingResponseListener implements Future<ContentResponse>
ABufferingResponseListenerthat is also aFuture, to allow applications to block (indefinitely or for a timeout) untilonComplete(Result)is called, or toabortthe request/response conversation.Typical usage is:
Request request = httpClient.newRequest(...)...; FutureResponseListener listener = new FutureResponseListener(request); request.send(listener); // Asynchronous send ContentResponse response = listener.get(5, TimeUnit.SECONDS); // Timed block
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.client.api.Response.Listener
Response.Listener.Adapter
-
-
Constructor Summary
Constructors Constructor Description FutureResponseListener(Request request)FutureResponseListener(Request request, int maxLength)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancancel(boolean mayInterruptIfRunning)ContentResponseget()ContentResponseget(long timeout, TimeUnit unit)RequestgetRequest()booleanisCancelled()booleanisDone()voidonComplete(Result result)Callback method invoked when the request and the response have been processed, either successfully or not.-
Methods inherited from class org.eclipse.jetty.client.util.BufferingResponseListener
getContent, getContentAsInputStream, getContentAsString, getContentAsString, getContentAsString, getEncoding, getMediaType, onContent, onHeaders
-
-
-
-
Method Detail
-
getRequest
public Request getRequest()
-
onComplete
public void onComplete(Result result)
Description copied from interface:Response.CompleteListenerCallback method invoked when the request and the response have been processed, either successfully or not.The
resultparameter contains the request, the response, and eventual failures.Requests may complete after response, for example in case of big uploads that are discarded or read asynchronously by the server. This method is always invoked after
Response.SuccessListener.onSuccess(Response)orResponse.FailureListener.onFailure(Response, Throwable), and only when request indicates that it is completed.- Specified by:
onCompletein interfaceResponse.CompleteListener- Specified by:
onCompletein classBufferingResponseListener- Parameters:
result- the result of the request / response exchange
-
cancel
public boolean cancel(boolean mayInterruptIfRunning)
- Specified by:
cancelin interfaceFuture<ContentResponse>
-
isCancelled
public boolean isCancelled()
- Specified by:
isCancelledin interfaceFuture<ContentResponse>
-
isDone
public boolean isDone()
- Specified by:
isDonein interfaceFuture<ContentResponse>
-
get
public ContentResponse get() throws InterruptedException, ExecutionException
- Specified by:
getin interfaceFuture<ContentResponse>- Throws:
InterruptedExceptionExecutionException
-
get
public ContentResponse get(long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException
- Specified by:
getin interfaceFuture<ContentResponse>- Throws:
InterruptedExceptionExecutionExceptionTimeoutException
-
-