From 3e46ea80efd6a97c6ea1b8c6ce8a7054acfe0698 Mon Sep 17 00:00:00 2001 From: Rowan Seymour Date: Thu, 22 Aug 2024 20:00:10 -0500 Subject: [PATCH] Improve error messages from failed S3 operations --- archives/s3.go | 23 ++++++----------------- 1 file changed, 6 insertions(+), 17 deletions(-) diff --git a/archives/s3.go b/archives/s3.go index 3e7aa1a..83bdc9d 100644 --- a/archives/s3.go +++ b/archives/s3.go @@ -118,18 +118,11 @@ func GetS3FileInfo(ctx context.Context, s3Client *s3x.Service, fileURL string) ( } bucket := strings.Split(u.Host, ".")[0] - path := strings.TrimPrefix(u.Path, "/") - - head, err := s3Client.Client.HeadObject( - ctx, - &s3.HeadObjectInput{ - Bucket: aws.String(bucket), - Key: aws.String(path), - }, - ) + key := strings.TrimPrefix(u.Path, "/") + head, err := s3Client.Client.HeadObject(ctx, &s3.HeadObjectInput{Bucket: aws.String(bucket), Key: aws.String(key)}) if err != nil { - return 0, "", err + return 0, "", fmt.Errorf("error looking up S3 object bucket=%s key=%s: %w", bucket, key, err) } if head.ContentLength == nil || head.ETag == nil { @@ -150,19 +143,15 @@ func GetS3File(ctx context.Context, s3Client *s3x.Service, fileURL string) (io.R } bucket := strings.Split(u.Host, ".")[0] - path := strings.TrimPrefix(u.Path, "/") + key := strings.TrimPrefix(u.Path, "/") output, err := s3Client.Client.GetObject( ctx, - &s3.GetObjectInput{ - Bucket: aws.String(bucket), - Key: aws.String(path), - }, + &s3.GetObjectInput{Bucket: aws.String(bucket), Key: aws.String(key)}, withAcceptEncoding("gzip"), ) - if err != nil { - return nil, err + return nil, fmt.Errorf("error fetching S3 object bucket=%s key=%s: %w", bucket, key, err) } return output.Body, nil