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

com.amazonaws.services.s3.transfer.internal.CopyPartRequestFactory Maven / Gradle / Ivy

/*
 * Copyright 2010-2017 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 com.amazonaws.services.s3.transfer.internal;

import com.amazonaws.services.s3.model.CopyObjectRequest;
import com.amazonaws.services.s3.model.CopyPartRequest;

/**
 * Factory for creating all the individual CopyPartRequest objects for a
 * multipart copy.
 * 

* This allows us to delay creating each CopyPartRequest until we're ready for * it, instead of immediately creating thousands of CopyPartRequest objects for * each large copy, when we won't need most of those request objects for a * while. */ public class CopyPartRequestFactory { /** Upload id to be used in each copy part request. */ private final String uploadId; /** Optimal size of each part in the copy request. */ private final long optimalPartSize; /** The original copy object request. */ private final CopyObjectRequest origReq; /** Part Number to be specified in each copy part request. */ private int partNumber = 1; /** Starting byte for each part. */ private long offset = 0; /** The number of remaining bytes to be copied. */ private long remainingBytes; public CopyPartRequestFactory(CopyObjectRequest origReq, String uploadId, long optimalPartSize, long contentLength) { this.origReq = origReq; this.uploadId = uploadId; this.optimalPartSize = optimalPartSize; this.remainingBytes = contentLength; } public synchronized boolean hasMoreRequests() { return (remainingBytes > 0); } /** * Constructs a copy part requests and returns it. * * @return Returns a new copy part request */ public synchronized CopyPartRequest getNextCopyPartRequest() { final long partSize = Math.min(optimalPartSize, remainingBytes); CopyPartRequest req = new CopyPartRequest() .withSourceBucketName(origReq.getSourceBucketName()) .withSourceKey(origReq.getSourceKey()) .withUploadId(uploadId) .withPartNumber(partNumber++) .withDestinationBucketName(origReq.getDestinationBucketName()) .withDestinationKey(origReq.getDestinationKey()) .withSourceVersionId(origReq.getSourceVersionId()) .withFirstByte(Long.valueOf(offset)) .withLastByte(Long.valueOf(offset + partSize - 1)) .withSourceSSECustomerKey(origReq.getSourceSSECustomerKey()) .withDestinationSSECustomerKey(origReq.getDestinationSSECustomerKey()) .withRequesterPays(origReq.isRequesterPays()) // other meta data .withMatchingETagConstraints(origReq.getMatchingETagConstraints()) .withModifiedSinceConstraint(origReq.getModifiedSinceConstraint()) .withNonmatchingETagConstraints(origReq.getNonmatchingETagConstraints()) .withSourceVersionId(origReq.getSourceVersionId()) .withUnmodifiedSinceConstraint(origReq.getUnmodifiedSinceConstraint()) // general meta data .withGeneralProgressListener(origReq.getGeneralProgressListener()) .withRequestMetricCollector(origReq.getRequestMetricCollector()) ; offset += partSize; remainingBytes -= partSize; return req; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy