Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

S3 TransferManager do not handle S3 object version while copying objects #848

Closed
kamoor opened this issue Sep 19, 2016 · 5 comments
Closed
Assignees
Labels
response-requested Waiting on additional info or feedback. Will move to "closing-soon" in 5 days.

Comments

@kamoor
Copy link

kamoor commented Sep 19, 2016

com.amazonaws.services.s3.transfer.TransferManager ends up with error if you try to copy an object with a version. This is because MetaData object do not consider the version while setting prior copy. See line 1776 in TranferManager.

line 1776
GetObjectMetadataRequest getObjectMetadataRequest = new GetObjectMetadataRequest(
copyObjectRequest.getSourceBucketName(), copyObjectRequest.getSourceKey())
.withSSECustomerKey(copyObjectRequest.getSourceSSECustomerKey());

@varunnvs92
Copy link
Contributor

Which version of the SDK are you using? Can you provide a test case to repo the issue and error log?

@kiiadi
Copy link
Contributor

kiiadi commented Sep 19, 2016

Are these large objects being copied? The TransferManager automatically uses a multi-part copy if the object is over a certain size (default is 5GB - see here TransferManagerConfiguration.java)

Unfortunately S3 doesn't handle meta-data copy on a multi-part copy - see related issue #367

You can explicitly set the metadata when you initiate the copy request and in this case it will get persisted -

copyObjectRequest.withNewObjectMetadata(metadata);

@kamoor
Copy link
Author

kamoor commented Sep 19, 2016

@kiiadi I think copy method in TransferManager will always create a new GetObjectMetadataRequest regardless of the fact copyObjectRequest has metadata set. See line 1776 in TransferManager

@kiiadi kiiadi self-assigned this Sep 19, 2016
@kiiadi
Copy link
Contributor

kiiadi commented Sep 19, 2016

What version of the SDK are you using? The TransferManager creates a CopyCallable object with the details of the CopyObjectRequest - when a multi-part copy is initiated; if newObjectMetadata exists on the CopyObjectRequest it will get used otherwise a new ObjectMetadata object is created.

See https://github.com/aws/aws-sdk-java/blob/master/aws-java-sdk-s3/src/main/java/com/amazonaws/services/s3/transfer/internal/CopyCallable.java#L239

@kiiadi
Copy link
Contributor

kiiadi commented Dec 16, 2016

Closing aged issue, please feel free to reopen if this is still a problem.

@kiiadi kiiadi closed this as completed Dec 16, 2016
@debora-ito debora-ito added response-requested Waiting on additional info or feedback. Will move to "closing-soon" in 5 days. and removed needs-response labels Feb 25, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
response-requested Waiting on additional info or feedback. Will move to "closing-soon" in 5 days.
Projects
None yet
Development

No branches or pull requests

5 participants