Class DeferredContentProvider
- java.lang.Object
-
- org.eclipse.jetty.client.util.DeferredContentProvider
-
- All Implemented Interfaces:
Closeable
,AutoCloseable
,Iterable<ByteBuffer>
,ContentProvider
,AsyncContentProvider
,Callback
,Invocable
@Deprecated(since="2021-05-27") public class DeferredContentProvider extends Object implements AsyncContentProvider, Callback, Closeable
Deprecated.The Eclipse Jetty and Apache Felix Http Jetty packages are no longer supported.AContentProvider
that allows to add content afterRequest.send(Response.CompleteListener)
has been called, therefore providing the request content at a later time.DeferredContentProvider
can only be used in conjunction withRequest.send(Response.CompleteListener)
(and not with its blocking counterpartRequest.send()
) because it provides content asynchronously.The deferred content is provided once and then fully consumed. Invocations to the
iterator()
method after the first will return an "empty" iterator because the stream has been consumed on the first invocation. However, it is possible for subclasses to overrideoffer(ByteBuffer)
andclose()
to copy the content to another location (for example a file) and be able to support multiple invocations of ofiterator()
returning the iterator provided by this class on the first invocation, and an iterator on the bytes copied to the other location for subsequent invocations.Typical usage of
DeferredContentProvider
is in asynchronous proxies, where HTTP headers arrive separately from HTTP content chunks.The deferred content must be provided through
offer(ByteBuffer)
, which can be invoked multiple times, and when all content has been provided it must be signaled with a call toclose()
.Example usage:
HttpClient httpClient = ...; // Use try-with-resources to autoclose DeferredContentProvider try (DeferredContentProvider content = new DeferredContentProvider()) { httpClient.newRequest("localhost", 8080) .content(content) .send(new Response.CompleteListener() { @Override public void onComplete(Result result) { // Your logic here } }); // At a later time... content.offer(ByteBuffer.wrap("some content".getBytes())); }
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
DeferredContentProvider.Chunk
Deprecated.-
Nested classes/interfaces inherited from interface org.eclipse.jetty.client.AsyncContentProvider
AsyncContentProvider.Listener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.Callback
Callback.Completable, Callback.Completing, Callback.Nested
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.client.api.ContentProvider
ContentProvider.Typed
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.thread.Invocable
Invocable.InvocationType
-
-
Field Summary
-
Fields inherited from interface org.eclipse.jetty.util.thread.Invocable
__nonBlocking
-
-
Constructor Summary
Constructors Constructor Description DeferredContentProvider(ByteBuffer... buffers)
Deprecated.Creates a newDeferredContentProvider
with the given initial content
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description void
close()
Deprecated.No more content will be added to this content provider and notifies the listener that no more content is available.void
failed(Throwable failure)
Deprecated.Callback invoked when the operation fails.void
flush()
Deprecated.long
getLength()
Deprecated.boolean
isClosed()
Deprecated.Iterator<ByteBuffer>
iterator()
Deprecated.boolean
offer(ByteBuffer buffer)
Deprecated.Adds the given content buffer to this content provider and notifies the listener that content is available.boolean
offer(ByteBuffer buffer, Callback callback)
Deprecated.void
setListener(AsyncContentProvider.Listener listener)
Deprecated.-
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.eclipse.jetty.client.api.ContentProvider
isReproducible
-
Methods inherited from interface org.eclipse.jetty.util.thread.Invocable
getInvocationType
-
Methods inherited from interface java.lang.Iterable
forEach, spliterator
-
-
-
-
Constructor Detail
-
DeferredContentProvider
public DeferredContentProvider(ByteBuffer... buffers)
Deprecated.Creates a newDeferredContentProvider
with the given initial content- Parameters:
buffers
- the initial content
-
-
Method Detail
-
setListener
public void setListener(AsyncContentProvider.Listener listener)
Deprecated.- Specified by:
setListener
in interfaceAsyncContentProvider
- Parameters:
listener
- the listener to be notified of content availability
-
getLength
public long getLength()
Deprecated.- Specified by:
getLength
in interfaceContentProvider
- Returns:
- the content length, if known, or -1 if the content length is unknown
-
offer
public boolean offer(ByteBuffer buffer)
Deprecated.Adds the given content buffer to this content provider and notifies the listener that content is available.- Parameters:
buffer
- the content to add- Returns:
- true if the content was added, false otherwise
-
offer
public boolean offer(ByteBuffer buffer, Callback callback)
Deprecated.
-
flush
public void flush() throws IOException
Deprecated.- Throws:
IOException
-
close
public void close()
Deprecated.No more content will be added to this content provider and notifies the listener that no more content is available.- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceCloseable
-
isClosed
public boolean isClosed()
Deprecated.
-
failed
public void failed(Throwable failure)
Deprecated.Description copied from interface:Callback
Callback invoked when the operation fails.
-
iterator
public Iterator<ByteBuffer> iterator()
Deprecated.- Specified by:
iterator
in interfaceIterable<ByteBuffer>
-
-