Browse Source

Fix PutMetadata with S3 backend (#176)

It turns out that the S3 API expects the additional `MetadataDirective:
REPLACE` option in order to update metadata. If this is not provided,
then metadata will simply be copied from the source object, which is not
what we wanted.
pull/178/head v2.1.4
mutantmonkey 6 years ago
committed by Andrei Marcu
parent
commit
872340e0dc
  1. 9
      backends/s3/s3.go

9
backends/s3/s3.go

@ -148,10 +148,11 @@ func (b S3Backend) Put(key string, r io.Reader, expiry time.Time, deleteKey stri
func (b S3Backend) PutMetadata(key string, m backends.Metadata) (err error) { func (b S3Backend) PutMetadata(key string, m backends.Metadata) (err error) {
_, err = b.svc.CopyObject(&s3.CopyObjectInput{ _, err = b.svc.CopyObject(&s3.CopyObjectInput{
Bucket: aws.String(b.bucket),
Key: aws.String(key),
CopySource: aws.String("/" + b.bucket + "/" + key),
Metadata: mapMetadata(m),
Bucket: aws.String(b.bucket),
Key: aws.String(key),
CopySource: aws.String("/" + b.bucket + "/" + key),
Metadata: mapMetadata(m),
MetadataDirective: aws.String("REPLACE"),
}) })
if err != nil { if err != nil {
return return

Loading…
Cancel
Save