All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.core.FileRequestBodyConfiguration Maven / Gradle / Ivy

/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */

package software.amazon.awssdk.core;

import java.nio.file.Path;
import java.util.Objects;
import software.amazon.awssdk.annotations.SdkPublicApi;
import software.amazon.awssdk.core.async.AsyncRequestBody;
import software.amazon.awssdk.utils.Validate;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * Configuration options for {@link AsyncRequestBody#fromFile(FileRequestBodyConfiguration)} to configure how the SDK
 * should read the file.
 *
 * @see #builder()
 */
@SdkPublicApi
public final class FileRequestBodyConfiguration implements ToCopyableBuilder {
    private final Integer chunkSizeInBytes;
    private final Long position;
    private final Long numBytesToRead;
    private final Path path;

    private FileRequestBodyConfiguration(DefaultBuilder builder) {
        this.path = Validate.notNull(builder.path, "path");
        this.chunkSizeInBytes = Validate.isPositiveOrNull(builder.chunkSizeInBytes, "chunkSizeInBytes");
        this.position = Validate.isNotNegativeOrNull(builder.position, "position");
        this.numBytesToRead = Validate.isNotNegativeOrNull(builder.numBytesToRead, "numBytesToRead");
    }

    /**
     * Create a {@link Builder}, used to create a {@link FileRequestBodyConfiguration}.
     */
    public static Builder builder() {
        return new DefaultBuilder();
    }

    /**
     * @return the size of each chunk to read from the file
     */
    public Integer chunkSizeInBytes() {
        return chunkSizeInBytes;
    }

    /**
     * @return the file position at which the request body begins.
     */
    public Long position() {
        return position;
    }

    /**
     * @return the number of bytes to read from this file.
     */
    public Long numBytesToRead() {
        return numBytesToRead;
    }

    /**
     * @return the file path
     */
    public Path path() {
        return path;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) {
            return true;
        }
        if (o == null || getClass() != o.getClass()) {
            return false;
        }

        FileRequestBodyConfiguration that = (FileRequestBodyConfiguration) o;

        if (!Objects.equals(chunkSizeInBytes, that.chunkSizeInBytes)) {
            return false;
        }
        if (!Objects.equals(position, that.position)) {
            return false;
        }
        if (!Objects.equals(numBytesToRead, that.numBytesToRead)) {
            return false;
        }
        return Objects.equals(path, that.path);
    }

    @Override
    public int hashCode() {
        int result = chunkSizeInBytes != null ? chunkSizeInBytes.hashCode() : 0;
        result = 31 * result + (position != null ? position.hashCode() : 0);
        result = 31 * result + (numBytesToRead != null ? numBytesToRead.hashCode() : 0);
        result = 31 * result + (path != null ? path.hashCode() : 0);
        return result;
    }

    @Override
    public Builder toBuilder() {
        return new DefaultBuilder(this);
    }

    public interface Builder extends CopyableBuilder {

        /**
         * Sets the {@link Path} to the file containing data to send to the service
         *
         * @param path Path to file to read.
         * @return This builder for method chaining.
         */
        Builder path(Path path);

        /**
         * Sets the size of chunks read from the file. Increasing this will cause more data to be buffered into memory but
         * may yield better latencies. Decreasing this will reduce memory usage but may cause reduced latency. Setting this value
         * is very dependent on upload speed and requires some performance testing to tune.
         *
         * 

The default chunk size is 16 KiB

* * @param chunkSize New chunk size in bytes. * @return This builder for method chaining. */ Builder chunkSizeInBytes(Integer chunkSize); /** * Sets the file position at which the request body begins. * *

By default, it's 0, i.e., reading from the beginning. * * @param position the position of the file * @return The builder for method chaining. */ Builder position(Long position); /** * Sets the number of bytes to read from this file. * *

By default, it's same as the file length. * * @param numBytesToRead number of bytes to read * @return The builder for method chaining. */ Builder numBytesToRead(Long numBytesToRead); } private static final class DefaultBuilder implements Builder { private Long position; private Path path; private Integer chunkSizeInBytes; private Long numBytesToRead; private DefaultBuilder(FileRequestBodyConfiguration configuration) { this.position = configuration.position; this.path = configuration.path; this.chunkSizeInBytes = configuration.chunkSizeInBytes; this.numBytesToRead = configuration.numBytesToRead; } private DefaultBuilder() { } @Override public Builder path(Path path) { this.path = path; return this; } @Override public Builder chunkSizeInBytes(Integer chunkSizeInBytes) { this.chunkSizeInBytes = chunkSizeInBytes; return this; } @Override public Builder position(Long position) { this.position = position; return this; } @Override public Builder numBytesToRead(Long numBytesToRead) { this.numBytesToRead = numBytesToRead; return this; } @Override public FileRequestBodyConfiguration build() { return new FileRequestBodyConfiguration(this); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy