From ac4c399643a127b0fffcad44555473f64746b895 Mon Sep 17 00:00:00 2001 From: aosti Date: Mon, 24 Jun 2024 11:31:55 -0300 Subject: [PATCH] feat: add acl support into s3 output --- internal/impl/aws/output_s3.go | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/internal/impl/aws/output_s3.go b/internal/impl/aws/output_s3.go index a8542ef6cb..d845bd9f82 100644 --- a/internal/impl/aws/output_s3.go +++ b/internal/impl/aws/output_s3.go @@ -49,6 +49,7 @@ const ( s3oFieldMetadata = "metadata" s3oFieldStorageClass = "storage_class" s3oFieldTimeout = "timeout" + s3oFieldACL = "acl" s3oFieldKMSKeyID = "kms_key_id" s3oFieldServerSideEncryption = "server_side_encryption" s3oFieldBatching = "batching" @@ -73,6 +74,7 @@ type s3oConfig struct { Metadata *service.MetadataExcludeFilter StorageClass *service.InterpolatedString Timeout time.Duration + ACL *service.InterpolatedString KMSKeyID string ServerSideEncryption string UsePathStyle bool @@ -133,6 +135,9 @@ func s3oConfigFromParsed(pConf *service.ParsedConfig) (conf s3oConfig, err error if conf.Timeout, err = pConf.FieldDuration(s3oFieldTimeout); err != nil { return } + if conf.ACL, err = pConf.FieldInterpolatedString(s3oFieldACL); err != nil { + return + } if conf.KMSKeyID, err = pConf.FieldString(s3oFieldKMSKeyID); err != nil { return } @@ -257,6 +262,11 @@ output: Description("The storage class to set for each object."). Default("STANDARD"). Advanced(), + service.NewInterpolatedStringEnumField(s3oFieldACL, + "private", "public-read", "public-read-write", "authenticated-read", "aws-exec-read", "bucket-owner-read", "bucket-owner-full-control"). + Description("The canned ACL to set for each object."). + Default(""). + Advanced(), service.NewStringField(s3oFieldKMSKeyID). Description("An optional server side encryption key."). Default(""). @@ -426,6 +436,15 @@ func (a *amazonS3Writer) WriteBatch(wctx context.Context, msg service.MessageBat uploadInput.Tagging = aws.String(strings.Join(tags, "&")) } + acl, err := msg.TryInterpolatedString(i, a.conf.ACL) + if err != nil { + return fmt.Errorf("acl interpolation: %w", err) + } + + if acl != "" { + uploadInput.ACL = types.ObjectCannedACL(acl) + } + if a.conf.KMSKeyID != "" { uploadInput.ServerSideEncryption = types.ServerSideEncryptionAwsKms uploadInput.SSEKMSKeyId = &a.conf.KMSKeyID