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

software.amazon.awssdk.transfer.s3.model.DownloadRequest Maven / Gradle / Ivy

Go to download

The S3 Transfer Manager allows customers to easily and optimally transfer objects and directories to and from S3.

There is a newer version: 2.28.4
Show newest version
/*
 * 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.transfer.s3.model;

import java.nio.file.Path;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Objects;
import java.util.function.Consumer;
import software.amazon.awssdk.annotations.SdkPublicApi;
import software.amazon.awssdk.core.async.AsyncResponseTransformer;
import software.amazon.awssdk.services.s3.model.GetObjectRequest;
import software.amazon.awssdk.services.s3.model.GetObjectResponse;
import software.amazon.awssdk.transfer.s3.S3TransferManager;
import software.amazon.awssdk.transfer.s3.model.DownloadRequest.TypedBuilder;
import software.amazon.awssdk.transfer.s3.progress.TransferListener;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.Validate;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * Represents the request to download an object identified by the bucket and key from S3 through the given
 * {@link AsyncResponseTransformer}. For
 * downloading to a file, you may use {@link DownloadFileRequest} instead.
 *
 * @see S3TransferManager#download(DownloadRequest)
 */
@SdkPublicApi
public final class DownloadRequest
    implements TransferObjectRequest,
               ToCopyableBuilder, DownloadRequest> {
    
    private final AsyncResponseTransformer responseTransformer;
    private final GetObjectRequest getObjectRequest;
    private final List transferListeners;

    private DownloadRequest(DefaultTypedBuilder builder) {
        this.responseTransformer = Validate.paramNotNull(builder.responseTransformer, "responseTransformer");
        this.getObjectRequest = Validate.paramNotNull(builder.getObjectRequest, "getObjectRequest");
        this.transferListeners = builder.transferListeners;
    }

    /**
     * Creates a builder that can be used to create a {@link DownloadRequest}.
     *
     * @see UntypedBuilder
     */
    public static UntypedBuilder builder() {
        return new DefaultUntypedBuilder();
    }


    @Override
    public TypedBuilder toBuilder() {
        return new DefaultTypedBuilder<>(this);
    }

    /**
     * The {@link Path} to file that response contents will be written to. The file must not exist or this method will throw an
     * exception. If the file is not writable by the current user then an exception will be thrown.
     *
     * @return the destination path
     */
    public AsyncResponseTransformer responseTransformer() {
        return responseTransformer;
    }

    /**
     * @return The {@link GetObjectRequest} request that should be used for the download
     */
    public GetObjectRequest getObjectRequest() {
        return getObjectRequest;
    }

    /**
     * @return the List of transferListeners.
     * @see TypedBuilder#transferListeners(Collection)
     */
    @Override
    public List transferListeners() {
        return transferListeners;
    }

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

        DownloadRequest that = (DownloadRequest) o;

        if (!Objects.equals(responseTransformer, that.responseTransformer)) {
            return false;
        }
        if (!Objects.equals(getObjectRequest, that.getObjectRequest)) {
            return false;
        }
        return Objects.equals(transferListeners, that.transferListeners);
    }

    @Override
    public int hashCode() {
        int result = responseTransformer != null ? responseTransformer.hashCode() : 0;
        result = 31 * result + (getObjectRequest != null ? getObjectRequest.hashCode() : 0);
        result = 31 * result + (transferListeners != null ? transferListeners.hashCode() : 0);
        return result;
    }

    @Override
    public String toString() {
        return ToString.builder("DownloadRequest")
                       .add("responseTransformer", responseTransformer)
                       .add("getObjectRequest", getObjectRequest)
                       .add("transferListeners", transferListeners)
                       .build();
    }

    /**
     * Initial calls to {@link DownloadRequest#builder()} return an {@link UntypedBuilder}, where the builder is not yet
     * parameterized with the generic type associated with {@link DownloadRequest}. This prevents the otherwise awkward syntax of
     * having to explicitly cast the builder type, e.g.,
     * 
     * {@code DownloadRequest.>builder()}
     * 
* Instead, the type may be inferred as part of specifying the {@link #responseTransformer(AsyncResponseTransformer)} * parameter, at which point the builder chain will return a new {@link TypedBuilder}. */ public interface UntypedBuilder { /** * The {@link GetObjectRequest} request that should be used for the download * * @param getObjectRequest the getObject request * @return a reference to this object so that method calls can be chained together. * @see #getObjectRequest(Consumer) */ UntypedBuilder getObjectRequest(GetObjectRequest getObjectRequest); /** * The {@link GetObjectRequest} request that should be used for the download *

* This is a convenience method that creates an instance of the {@link GetObjectRequest} builder, avoiding the need to * create one manually via {@link GetObjectRequest#builder()}. * * @param getObjectRequestBuilder the getObject request * @return a reference to this object so that method calls can be chained together. * @see #getObjectRequest(GetObjectRequest) */ default UntypedBuilder getObjectRequest(Consumer getObjectRequestBuilder) { GetObjectRequest request = GetObjectRequest.builder() .applyMutation(getObjectRequestBuilder) .build(); getObjectRequest(request); return this; } /** * The {@link TransferListener}s that will be notified as part of this request. This method overrides and replaces any * transferListeners that have already been set. Add an optional request override configuration. * * @param transferListeners the collection of transferListeners * @return Returns a reference to this object so that method calls can be chained together. * @return This builder for method chaining. * @see TransferListener */ UntypedBuilder transferListeners(Collection transferListeners); /** * Adds a {@link TransferListener} that will be notified as part of this request. * * @param transferListener the transferListener to add * @return Returns a reference to this object so that method calls can be chained together. * @see TransferListener */ UntypedBuilder addTransferListener(TransferListener transferListener); /** * Specifies the {@link AsyncResponseTransformer} that should be used for the download. This method also infers the * generic type of {@link DownloadRequest} to create, inferred from the second type parameter of the provided {@link * AsyncResponseTransformer}. E.g, specifying {@link AsyncResponseTransformer#toBytes()} would result in inferring the * type of the {@link DownloadRequest} to be of {@code ResponseBytes}. See the static factory methods * available in {@link AsyncResponseTransformer}. * * @param responseTransformer the AsyncResponseTransformer * @param the type of {@link DownloadRequest} to create * @return a reference to this object so that method calls can be chained together. * @see AsyncResponseTransformer */ TypedBuilder responseTransformer(AsyncResponseTransformer responseTransformer); } private static final class DefaultUntypedBuilder implements UntypedBuilder { private GetObjectRequest getObjectRequest; private List transferListeners; private DefaultUntypedBuilder() { } @Override public UntypedBuilder getObjectRequest(GetObjectRequest getObjectRequest) { this.getObjectRequest = getObjectRequest; return this; } @Override public UntypedBuilder transferListeners(Collection transferListeners) { this.transferListeners = transferListeners != null ? new ArrayList<>(transferListeners) : null; return this; } @Override public UntypedBuilder addTransferListener(TransferListener transferListener) { if (transferListeners == null) { transferListeners = new ArrayList<>(); } transferListeners.add(transferListener); return this; } public List getTransferListeners() { return transferListeners; } public void setTransferListeners(Collection transferListeners) { transferListeners(transferListeners); } @Override public TypedBuilder responseTransformer(AsyncResponseTransformer responseTransformer) { return new DefaultTypedBuilder() .getObjectRequest(getObjectRequest) .transferListeners(transferListeners) .responseTransformer(responseTransformer); } } /** * The type-parameterized version of {@link UntypedBuilder}. This builder's type is inferred as part of specifying {@link * UntypedBuilder#responseTransformer(AsyncResponseTransformer)}, after which this builder can be used to construct a {@link * DownloadRequest} with the same generic type. */ public interface TypedBuilder extends CopyableBuilder, DownloadRequest> { /** * The {@link GetObjectRequest} request that should be used for the download * * @param getObjectRequest the getObject request * @return a reference to this object so that method calls can be chained together. * @see #getObjectRequest(Consumer) */ TypedBuilder getObjectRequest(GetObjectRequest getObjectRequest); /** * The {@link GetObjectRequest} request that should be used for the download *

* This is a convenience method that creates an instance of the {@link GetObjectRequest} builder, avoiding the need to * create one manually via {@link GetObjectRequest#builder()}. * * @param getObjectRequestBuilder the getObject request * @return a reference to this object so that method calls can be chained together. * @see #getObjectRequest(GetObjectRequest) */ default TypedBuilder getObjectRequest(Consumer getObjectRequestBuilder) { GetObjectRequest request = GetObjectRequest.builder() .applyMutation(getObjectRequestBuilder) .build(); getObjectRequest(request); return this; } /** * The {@link TransferListener}s that will be notified as part of this request. This method overrides and replaces any * transferListeners that have already been set. Add an optional request override configuration. * * @param transferListeners the collection of transferListeners * @return Returns a reference to this object so that method calls can be chained together. * @return This builder for method chaining. * @see TransferListener */ TypedBuilder transferListeners(Collection transferListeners); /** * Add a {@link TransferListener} that will be notified as part of this request. * * @param transferListener the transferListener to add * @return Returns a reference to this object so that method calls can be chained together. * @see TransferListener */ TypedBuilder addTransferListener(TransferListener transferListener); /** * Specifies the {@link AsyncResponseTransformer} that should be used for the download. The generic type used is * constrained by the {@link UntypedBuilder#responseTransformer(AsyncResponseTransformer)} that was previously used to * create this {@link TypedBuilder}. * * @param responseTransformer the AsyncResponseTransformer * @return a reference to this object so that method calls can be chained together. * @see AsyncResponseTransformer */ TypedBuilder responseTransformer(AsyncResponseTransformer responseTransformer); } private static class DefaultTypedBuilder implements TypedBuilder { private GetObjectRequest getObjectRequest; private List transferListeners; private AsyncResponseTransformer responseTransformer; private DefaultTypedBuilder() { } private DefaultTypedBuilder(DownloadRequest request) { this.getObjectRequest = request.getObjectRequest; this.responseTransformer = request.responseTransformer; this.transferListeners = request.transferListeners; } @Override public TypedBuilder getObjectRequest(GetObjectRequest getObjectRequest) { this.getObjectRequest = getObjectRequest; return this; } @Override public TypedBuilder responseTransformer(AsyncResponseTransformer responseTransformer) { this.responseTransformer = responseTransformer; return this; } @Override public TypedBuilder transferListeners(Collection transferListeners) { this.transferListeners = transferListeners != null ? new ArrayList<>(transferListeners) : null; return this; } @Override public TypedBuilder addTransferListener(TransferListener transferListener) { if (transferListeners == null) { transferListeners = new ArrayList<>(); } transferListeners.add(transferListener); return this; } public List getTransferListeners() { return transferListeners; } public void setTransferListeners(Collection transferListeners) { transferListeners(transferListeners); } @Override public DownloadRequest build() { return new DownloadRequest<>(this); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy