Class FileAsyncRequestBody
- All Implemented Interfaces:
org.reactivestreams.Publisher<ByteBuffer>,AsyncRequestBody,SdkPublisher<ByteBuffer>
AsyncRequestBody that reads data from a file.- See Also:
-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from interface software.amazon.awssdk.core.async.AsyncRequestBody
AsyncRequestBody.BodyType -
Method Summary
Modifier and TypeMethodDescriptionbody()Each AsyncRequestBody should return a well-formed name that can be used to identify the implementation.static FileAsyncRequestBody.Builderbuilder()intlonglongpath()longposition()split(AsyncRequestBodySplitConfiguration splitConfiguration) Converts thisAsyncRequestBodyto a publisher ofAsyncRequestBodys, each of which publishes a specific portion of the original data, based on the providedAsyncRequestBodySplitConfiguration.splitCloseable(AsyncRequestBodySplitConfiguration splitConfiguration) Converts thisAsyncRequestBodyto a publisher ofCloseableAsyncRequestBodys, each of which publishes specific portion of the original data, based on the providedAsyncRequestBodySplitConfiguration.voidsubscribe(org.reactivestreams.Subscriber<? super ByteBuffer> s) Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface software.amazon.awssdk.core.async.AsyncRequestBody
split, splitCloseableMethods inherited from interface software.amazon.awssdk.core.async.SdkPublisher
addTrailingData, buffer, doAfterOnCancel, doAfterOnComplete, doAfterOnError, filter, filter, flatMapIterable, limit, map, subscribe
-
Method Details
-
split
Description copied from interface:AsyncRequestBodyConverts 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.- Specified by:
splitin interfaceAsyncRequestBody
-
splitCloseable
public SdkPublisher<CloseableAsyncRequestBody> splitCloseable(AsyncRequestBodySplitConfiguration splitConfiguration) Description copied from interface:AsyncRequestBodyConverts 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
AsyncRequestBody.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.
- Specified by:
splitCloseablein interfaceAsyncRequestBody- See Also:
-
path
-
fileLength
public long fileLength() -
chunkSizeInBytes
public int chunkSizeInBytes() -
position
public long position() -
numBytesToRead
public long numBytesToRead() -
modifiedTimeAtStart
-
sizeAtStart
-
contentLength
- Specified by:
contentLengthin interfaceAsyncRequestBody- Returns:
- The content length of the data being produced.
-
contentType
- Specified by:
contentTypein interfaceAsyncRequestBody- Returns:
- The content type of the data being produced.
-
subscribe
- Specified by:
subscribein interfaceorg.reactivestreams.Publisher<ByteBuffer>
-
body
Description copied from interface:AsyncRequestBodyEach AsyncRequestBody should return a well-formed name that can be used to identify the implementation. The body name should only include alphanumeric characters.- Specified by:
bodyin interfaceAsyncRequestBody- Returns:
- String containing the identifying name of this AsyncRequestBody implementation.
-
builder
- Returns:
- Builder instance to construct a
FileAsyncRequestBody.
-