chore: switch to AWS SDK v2
This commit is contained in:
+14
-8
@@ -1,25 +1,30 @@
|
||||
package storage
|
||||
|
||||
import (
|
||||
"context"
|
||||
"io"
|
||||
|
||||
"github.com/aws/aws-sdk-go/aws"
|
||||
"github.com/aws/aws-sdk-go/aws/session"
|
||||
"github.com/aws/aws-sdk-go/service/s3/s3manager"
|
||||
"github.com/aws/aws-sdk-go/service/s3/s3manager/s3manageriface"
|
||||
"github.com/aws/aws-sdk-go-v2/aws"
|
||||
"github.com/aws/aws-sdk-go-v2/config"
|
||||
"github.com/aws/aws-sdk-go-v2/feature/s3/manager"
|
||||
"github.com/aws/aws-sdk-go-v2/service/s3"
|
||||
)
|
||||
|
||||
type Storage interface {
|
||||
Store(path string, content io.Reader) error
|
||||
}
|
||||
|
||||
type Uploader interface {
|
||||
Upload(ctx context.Context, input *s3.PutObjectInput, opts ...func(*manager.Uploader)) (*manager.UploadOutput, error)
|
||||
}
|
||||
|
||||
type S3 struct {
|
||||
bucket string
|
||||
svc s3manageriface.UploaderAPI
|
||||
svc Uploader
|
||||
}
|
||||
|
||||
func (s *S3) Store(path string, content io.Reader) error {
|
||||
_, err := s.svc.Upload(&s3manager.UploadInput{
|
||||
_, err := s.svc.Upload(context.Background(), &s3.PutObjectInput{
|
||||
Bucket: aws.String(s.bucket),
|
||||
Key: aws.String(path),
|
||||
Body: content,
|
||||
@@ -28,11 +33,12 @@ func (s *S3) Store(path string, content io.Reader) error {
|
||||
}
|
||||
|
||||
func New(bucket string) (Storage, error) {
|
||||
sess, err := session.NewSession(aws.NewConfig())
|
||||
cfg, err := config.LoadDefaultConfig(context.Background())
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
uploader := s3manager.NewUploader(sess, func(u *s3manager.Uploader) {
|
||||
client := s3.NewFromConfig(cfg)
|
||||
uploader := manager.NewUploader(client, func(u *manager.Uploader) {
|
||||
u.PartSize = 5 * 1024 * 1024
|
||||
})
|
||||
return &S3{bucket: bucket, svc: uploader}, nil
|
||||
|
||||
+15
-19
@@ -1,16 +1,16 @@
|
||||
package storage
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"io"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"strings"
|
||||
"testing"
|
||||
|
||||
"github.com/aws/aws-sdk-go/aws"
|
||||
"github.com/aws/aws-sdk-go/service/s3/s3manager"
|
||||
"github.com/aws/aws-sdk-go/service/s3/s3manager/s3manageriface"
|
||||
"github.com/aws/aws-sdk-go-v2/aws"
|
||||
"github.com/aws/aws-sdk-go-v2/feature/s3/manager"
|
||||
"github.com/aws/aws-sdk-go-v2/service/s3"
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
@@ -28,9 +28,9 @@ func TestNew(t *testing.T) {
|
||||
name: "invalid AWS config",
|
||||
args: args{},
|
||||
setup: func() func() {
|
||||
_ = os.Setenv("AWS_STS_REGIONAL_ENDPOINTS", "unknown_value")
|
||||
_ = os.Setenv("AWS_MAX_ATTEMPTS", "invalid")
|
||||
return func() {
|
||||
_ = os.Unsetenv("AWS_STS_REGIONAL_ENDPOINTS")
|
||||
_ = os.Unsetenv("AWS_MAX_ATTEMPTS")
|
||||
}
|
||||
},
|
||||
wantErr: true,
|
||||
@@ -60,7 +60,7 @@ func TestNew(t *testing.T) {
|
||||
func TestS3_Store(t *testing.T) {
|
||||
type fields struct {
|
||||
bucket string
|
||||
svc func(t *testing.T) s3manageriface.UploaderAPI
|
||||
svc func(t *testing.T) Uploader
|
||||
}
|
||||
type args struct {
|
||||
path string
|
||||
@@ -76,12 +76,12 @@ func TestS3_Store(t *testing.T) {
|
||||
name: "upload error",
|
||||
fields: fields{
|
||||
bucket: "some-bucket",
|
||||
svc: func(t *testing.T) s3manageriface.UploaderAPI {
|
||||
svc: func(t *testing.T) Uploader {
|
||||
return &mock{
|
||||
upload: func(input *s3manager.UploadInput, f ...func(*s3manager.Uploader)) (*s3manager.UploadOutput, error) {
|
||||
upload: func(ctx context.Context, input *s3.PutObjectInput, f ...func(*manager.Uploader)) (*manager.UploadOutput, error) {
|
||||
assert.Equal(t, aws.String("some-bucket"), input.Bucket)
|
||||
assert.Equal(t, aws.String("/some/path"), input.Key)
|
||||
buff, err := ioutil.ReadAll(input.Body)
|
||||
buff, err := io.ReadAll(input.Body)
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, "some content", string(buff))
|
||||
return nil, fmt.Errorf("error")
|
||||
@@ -98,7 +98,7 @@ func TestS3_Store(t *testing.T) {
|
||||
}
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
var svc s3manageriface.UploaderAPI
|
||||
var svc Uploader
|
||||
if tt.fields.svc != nil {
|
||||
svc = tt.fields.svc(t)
|
||||
}
|
||||
@@ -114,18 +114,14 @@ func TestS3_Store(t *testing.T) {
|
||||
}
|
||||
|
||||
type mock struct {
|
||||
upload func(input *s3manager.UploadInput, f ...func(*s3manager.Uploader)) (*s3manager.UploadOutput, error)
|
||||
upload func(ctx context.Context, input *s3.PutObjectInput, f ...func(*manager.Uploader)) (*manager.UploadOutput, error)
|
||||
}
|
||||
|
||||
func (m *mock) Upload(input *s3manager.UploadInput, f ...func(*s3manager.Uploader)) (*s3manager.UploadOutput, error) {
|
||||
func (m *mock) Upload(ctx context.Context, input *s3.PutObjectInput, f ...func(*manager.Uploader)) (*manager.UploadOutput, error) {
|
||||
if m.upload != nil {
|
||||
return m.upload(input, f...)
|
||||
return m.upload(ctx, input, f...)
|
||||
}
|
||||
return nil, nil
|
||||
}
|
||||
|
||||
func (m *mock) UploadWithContext(aws.Context, *s3manager.UploadInput, ...func(*s3manager.Uploader)) (*s3manager.UploadOutput, error) {
|
||||
panic("implement me")
|
||||
}
|
||||
|
||||
var _ s3manageriface.UploaderAPI = &mock{}
|
||||
var _ Uploader = &mock{}
|
||||
|
||||
Reference in New Issue
Block a user