Interface AsyncRequestBody
- 
- All Superinterfaces:
- org.reactivestreams.Publisher<ByteBuffer>,- SdkPublisher<ByteBuffer>
 - All Known Subinterfaces:
- CloseableAsyncRequestBody,- SubAsyncRequestBody
 - All Known Implementing Classes:
- AsyncRequestBodyListener.NotifyingAsyncRequestBody,- BlockingInputStreamAsyncRequestBody,- BlockingOutputStreamAsyncRequestBody,- BufferedSplittableAsyncRequestBody,- ByteBuffersAsyncRequestBody,- ChecksumCalculatingAsyncRequestBody,- CompressionAsyncRequestBody,- FileAsyncRequestBody,- InputStreamWithExecutorAsyncRequestBody,- NonRetryableSubAsyncRequestBody,- RetryableSubAsyncRequestBody
 
 public interface AsyncRequestBody extends SdkPublisher<ByteBuffer> Interface to allow non-blocking streaming of request content. This follows the reactive streams pattern where this interface is thePublisherof data (specificallyByteBufferchunks) and the HTTP client is the Subscriber of the data (i.e. to write that data on the wire).Publisher.subscribe(Subscriber)should be implemented to tie this publisher to a subscriber. Ideally each call to subscribe should reproduce the content (i.e if you are reading from a file each subscribe call should produce aSubscriptionthat reads the file fully). This allows for automatic retries to be performed in the SDK. If the content is not reproducible, an exception may be thrown from any subsequentPublisher.subscribe(Subscriber)calls.It is important to only send the number of chunks that the subscriber requests to avoid out of memory situations. The subscriber does it's own buffering so it's usually not needed to buffer in the publisher. Additional permits for chunks will be notified via the Subscription.request(long)method.- See Also:
- FileAsyncRequestBody,- ByteBuffersAsyncRequestBody
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Interface Description static classAsyncRequestBody.BodyType
 - 
Method Summary- 
Methods inherited from interface software.amazon.awssdk.core.async.SdkPublisheraddTrailingData, buffer, doAfterOnCancel, doAfterOnComplete, doAfterOnError, filter, filter, flatMapIterable, limit, map, subscribe
 
- 
 
- 
- 
- 
Method Detail- 
contentLengthOptional<Long> contentLength() - Returns:
- The content length of the data being produced.
 
 - 
contentTypedefault String contentType() - Returns:
- The content type of the data being produced.
 
 - 
bodydefault String body() Each AsyncRequestBody should return a well-formed name that can be used to identify the implementation. The body name should only include alphanumeric characters.- Returns:
- String containing the identifying name of this AsyncRequestBody implementation.
 
 - 
fromPublisherstatic AsyncRequestBody fromPublisher(org.reactivestreams.Publisher<ByteBuffer> publisher) Creates anAsyncRequestBodythe produces data from the input ByteBuffer publisher. The data is delivered when the publisher publishes the data.- Parameters:
- publisher- Publisher of source data
- Returns:
- Implementation of AsyncRequestBodythat produces data send by the publisher
 
 - 
fromFilestatic AsyncRequestBody fromFile(Path path) Creates anAsyncRequestBodythat produces data from the contents of a file. SeeFileAsyncRequestBody.builder()to create a customized body implementation.- Parameters:
- path- Path to file to read from.
- Returns:
- Implementation of AsyncRequestBodythat reads data from the specified file.
- See Also:
- FileAsyncRequestBody
 
 - 
fromFilestatic AsyncRequestBody fromFile(File file) Creates anAsyncRequestBodythat produces data from the contents of a file. SeefromFile(FileRequestBodyConfiguration)to create a customized body implementation.- Parameters:
- file- The file to read from.
- Returns:
- Implementation of AsyncRequestBodythat reads data from the specified file.
 
 - 
fromFilestatic AsyncRequestBody fromFile(FileRequestBodyConfiguration configuration) Creates anAsyncRequestBodythat produces data from the contents of a file.- Parameters:
- configuration- configuration for how the SDK should read the file
- Returns:
- Implementation of AsyncRequestBodythat reads data from the specified file.
 
 - 
fromFilestatic AsyncRequestBody fromFile(Consumer<FileRequestBodyConfiguration.Builder> configuration) Creates anAsyncRequestBodythat produces data from the contents of a file.This is a convenience method that creates an instance of the FileRequestBodyConfigurationbuilder, avoiding the need to create one manually viaFileRequestBodyConfiguration.builder().- Parameters:
- configuration- configuration for how the SDK should read the file
- Returns:
- Implementation of AsyncRequestBodythat reads data from the specified file.
 
 - 
fromStringstatic AsyncRequestBody fromString(String string, Charset cs) Creates anAsyncRequestBodythat uses a single string as data.- Parameters:
- string- The string to provide.
- cs- The- Charsetto use.
- Returns:
- Implementation of AsyncRequestBodythat uses the specified string.
- See Also:
- ByteBuffersAsyncRequestBody
 
 - 
fromStringstatic AsyncRequestBody fromString(String string) Creates anAsyncRequestBodythat uses a single string as data with UTF_8 encoding.- Parameters:
- string- The string to send.
- Returns:
- Implementation of AsyncRequestBodythat uses the specified string.
- See Also:
- fromString(String, Charset)
 
 - 
fromBytesstatic AsyncRequestBody fromBytes(byte[] bytes) Creates anAsyncRequestBodyfrom a byte array. This will copy the contents of the byte array to prevent modifications to the provided byte array from being reflected in theAsyncRequestBody.- Parameters:
- bytes- The bytes to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromBytesUnsafestatic AsyncRequestBody fromBytesUnsafe(byte[] bytes) Creates anAsyncRequestBodyfrom a byte array without copying the contents of the byte array. This introduces concurrency risks, allowing: (1) the caller to modify the byte array stored in thisAsyncRequestBodyimplementation AND (2) any users offromBytesUnsafe(byte[])to modify the byte array passed into thisAsyncRequestBodyimplementation.As the method name implies, this is unsafe. Use fromBytes(byte[])unless you're sure you know the risks.- Parameters:
- bytes- The bytes to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromByteBufferstatic AsyncRequestBody fromByteBuffer(ByteBuffer byteBuffer) Creates anAsyncRequestBodyfrom aByteBuffer. This will copy the contents of theByteBufferto prevent modifications to the providedByteBufferfrom being reflected in theAsyncRequestBody.NOTE: This method ignores the current read position. Use fromRemainingByteBuffer(ByteBuffer)if you need it to copy only the remaining readable bytes.- Parameters:
- byteBuffer- ByteBuffer to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromRemainingByteBufferstatic AsyncRequestBody fromRemainingByteBuffer(ByteBuffer byteBuffer) Creates anAsyncRequestBodyfrom the remaining readable bytes from aByteBuffer. This will copy the remaining contents of theByteBufferto prevent modifications to the providedByteBufferfrom being reflected in theAsyncRequestBody.Unlike fromByteBuffer(ByteBuffer), this method respects the current read position of the buffer and reads only the remaining bytes.- Parameters:
- byteBuffer- ByteBuffer to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromByteBufferUnsafestatic AsyncRequestBody fromByteBufferUnsafe(ByteBuffer byteBuffer) Creates anAsyncRequestBodyfrom aByteBufferwithout copying the contents of theByteBuffer. This introduces concurrency risks, allowing the caller to modify theByteBufferstored in thisAsyncRequestBodyimplementation.NOTE: This method ignores the current read position. Use fromRemainingByteBufferUnsafe(ByteBuffer)if you need it to copy only the remaining readable bytes.As the method name implies, this is unsafe. Use fromByteBuffer(ByteBuffer)} unless you're sure you know the risks.- Parameters:
- byteBuffer- ByteBuffer to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromRemainingByteBufferUnsafestatic AsyncRequestBody fromRemainingByteBufferUnsafe(ByteBuffer byteBuffer) Creates anAsyncRequestBodyfrom aByteBufferwithout copying the contents of theByteBuffer. This introduces concurrency risks, allowing the caller to modify theByteBufferstored in thisAsyncRequestBodyimplementation.Unlike fromByteBufferUnsafe(ByteBuffer), this method respects the current read position of the buffer and reads only the remaining bytes.As the method name implies, this is unsafe. Use fromByteBuffer(ByteBuffer)} unless you're sure you know the risks.- Parameters:
- byteBuffer- ByteBuffer to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromByteBuffersstatic AsyncRequestBody fromByteBuffers(ByteBuffer... byteBuffers) Creates anAsyncRequestBodyfrom aByteBufferarray. This will copy the contents of eachByteBufferto prevent modifications to any providedByteBufferfrom being reflected in theAsyncRequestBody.NOTE: This method ignores the current read position of each ByteBuffer. UsefromRemainingByteBuffers(ByteBuffer...)if you need it to copy only the remaining readable bytes.- Parameters:
- byteBuffers- ByteBuffer array to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromRemainingByteBuffersstatic AsyncRequestBody fromRemainingByteBuffers(ByteBuffer... byteBuffers) Creates anAsyncRequestBodyfrom aByteBufferarray. This will copy the remaining contents of eachByteBufferto prevent modifications to any providedByteBufferfrom being reflected in theAsyncRequestBody.Unlike fromByteBufferUnsafe(ByteBuffer), this method respects the current read position of each buffer and reads only the remaining bytes.- Parameters:
- byteBuffers- ByteBuffer array to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromByteBuffersUnsafestatic AsyncRequestBody fromByteBuffersUnsafe(ByteBuffer... byteBuffers) Creates anAsyncRequestBodyfrom aByteBufferarray without copying the contents of eachByteBuffer. This introduces concurrency risks, allowing the caller to modify anyByteBufferstored in thisAsyncRequestBodyimplementation.NOTE: This method ignores the current read position of each ByteBuffer. UsefromRemainingByteBuffers(ByteBuffer...)if you need it to copy only the remaining readable bytes.As the method name implies, this is unsafe. Use fromByteBuffers(ByteBuffer...)unless you're sure you know the risks.- Parameters:
- byteBuffers- ByteBuffer array to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromRemainingByteBuffersUnsafestatic AsyncRequestBody fromRemainingByteBuffersUnsafe(ByteBuffer... byteBuffers) Creates anAsyncRequestBodyfrom aByteBufferarray without copying the contents of eachByteBuffer. This introduces concurrency risks, allowing the caller to modify anyByteBufferstored in thisAsyncRequestBodyimplementation.Unlike fromByteBuffersUnsafe(ByteBuffer...), this method respects the current read position of each buffer and reads only the remaining bytes.As the method name implies, this is unsafe. Use fromByteBuffers(ByteBuffer...)unless you're sure you know the risks.- Parameters:
- byteBuffers- ByteBuffer array to send to the service.
- Returns:
- AsyncRequestBody instance.
 
 - 
fromInputStreamstatic AsyncRequestBody fromInputStream(InputStream inputStream, Long contentLength, ExecutorService executor) Creates anAsyncRequestBodyfrom anInputStream.An ExecutorServiceis required in order to perform the blocking data reads, to prevent blocking the non-blocking event loop threads owned by the SDK.- Parameters:
- inputStream- The input stream containing the data to be sent
- contentLength- The content length. If a content length smaller than the actual size of the object is set, the client will truncate the stream to the specified content length and only send exactly the number of bytes equal to the content length.
- executor- The executor
- Returns:
- An AsyncRequestBody instance for the input stream
 
 - 
fromInputStreamstatic AsyncRequestBody fromInputStream(AsyncRequestBodyFromInputStreamConfiguration configuration) Creates anAsyncRequestBodyfrom anInputStreamwith the providedAsyncRequestBodySplitConfiguration.
 - 
fromInputStreamstatic AsyncRequestBody fromInputStream(Consumer<AsyncRequestBodyFromInputStreamConfiguration.Builder> configuration) This is a convenience method that passes an instance of theAsyncRequestBodyFromInputStreamConfigurationbuilder, avoiding the need to create one manually viaAsyncRequestBodyFromInputStreamConfiguration.builder().
 - 
forBlockingInputStreamstatic BlockingInputStreamAsyncRequestBody forBlockingInputStream(Long contentLength) Creates aBlockingInputStreamAsyncRequestBodyto use for writing an input stream to the downstream service.By default, it will time out if streaming hasn't started within 10 seconds, and use application/octet-stream as content type. You can configure it via BlockingInputStreamAsyncRequestBody.builder()Example Usage - Parameters:
- contentLength- The content length. If a content length smaller than the actual size of the object is set, the client will truncate the stream to the specified content length and only send exactly the number of bytes equal to the content length.
- Returns:
- The created BlockingInputStreamAsyncRequestBody.
 
 - 
forBlockingOutputStreamstatic BlockingOutputStreamAsyncRequestBody forBlockingOutputStream(Long contentLength) Creates aBlockingOutputStreamAsyncRequestBodyto use for writing to the downstream service as if it's an output stream. Retries are not supported for this request body.The caller is responsible for calling OutputStream.close()on theBlockingOutputStreamAsyncRequestBody.outputStream()when writing is complete.By default, it will time out if streaming hasn't started within 10 seconds, and you can configure the timeout via BlockingOutputStreamAsyncRequestBody.builder()Example Usage - Parameters:
- contentLength- The content length. If a content length smaller than the actual size of the object is set, the client will truncate the stream to the specified content length and only send exactly the number of bytes equal to the content length.
- Returns:
- The created BlockingOutputStreamAsyncRequestBody.
- See Also:
- BlockingOutputStreamAsyncRequestBody
 
 - 
emptystatic AsyncRequestBody empty() Creates anAsyncRequestBodywith no content.- Returns:
- AsyncRequestBody instance.
 
 - 
split@Deprecated default SdkPublisher<AsyncRequestBody> split(AsyncRequestBodySplitConfiguration splitConfiguration) Deprecated.usesplitCloseable(AsyncRequestBodySplitConfiguration)instead.Converts thisAsyncRequestBodyto a publisher ofAsyncRequestBodys, each of which publishes a specific portion of the original data, based on the providedAsyncRequestBodySplitConfiguration. The default chunk size is 2MB and the default buffer size is 8MB.By default, if content length of this AsyncRequestBodyis present, each dividedAsyncRequestBodyis delivered to the subscriber right after it's initialized. On the other hand, if content length is null, it is sent after the entire content for that chunk is buffered. In this case, the configuredmaxMemoryUsageInBytesmust be larger than or equal tochunkSizeInBytes. Note that this behavior may be different if a specific implementation of this interface overrides this method.
 - 
splitCloseabledefault SdkPublisher<CloseableAsyncRequestBody> splitCloseable(AsyncRequestBodySplitConfiguration splitConfiguration) Converts thisAsyncRequestBodyto a publisher ofCloseableAsyncRequestBodys, each of which publishes specific portion of the original data, based on the providedAsyncRequestBodySplitConfiguration. The default chunk size is 2MB and the default buffer size is 8MB.The default implementation behaves the same as split(AsyncRequestBodySplitConfiguration). This behavior may vary in different implementations.Caller is responsible for closing CloseableAsyncRequestBodywhen it is ready to be disposed to release any resources.Note: This method is primarily intended for use by AWS SDK high-level libraries and internal components. SDK customers should typically use higher-level APIs provided by service clients rather than calling this method directly. 
 - 
split@Deprecated default SdkPublisher<AsyncRequestBody> split(Consumer<AsyncRequestBodySplitConfiguration.Builder> splitConfiguration) Deprecated.usesplitCloseable(Consumer)insteadThis is a convenience method that passes an instance of theAsyncRequestBodySplitConfigurationbuilder, avoiding the need to create one manually viaAsyncRequestBodySplitConfiguration.builder().
 - 
splitCloseabledefault SdkPublisher<CloseableAsyncRequestBody> splitCloseable(Consumer<AsyncRequestBodySplitConfiguration.Builder> splitConfiguration) This is a convenience method that passes an instance of theAsyncRequestBodySplitConfigurationbuilder, avoiding the need to create one manually viaAsyncRequestBodySplitConfiguration.builder().Note: This method is primarily intended for use by AWS SDK high-level libraries and internal components. SDK customers should typically use higher-level APIs provided by service clients rather than calling this method directly. 
 
- 
 
-