-
Notifications
You must be signed in to change notification settings - Fork 656
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Feat s3 transfer manager v2 PutObject (#2733)
* recommit transfer manager v2 files * change pool to store slice pointer * add integ test for putobject * update go mod * minor changes for v0.1.0 * update tags * update tags * update integ test dependency version * change err var name * update go mod * change input/output type comment * minor change --------- Co-authored-by: Tianyi Wang <[email protected]>
- Loading branch information
1 parent
061540b
commit 43b305d
Showing
18 changed files
with
3,039 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
package transfermanager | ||
|
||
import ( | ||
"context" | ||
|
||
"github.com/aws/aws-sdk-go-v2/service/s3" | ||
) | ||
|
||
// S3APIClient defines an interface doing S3 client side operations for transfer manager | ||
type S3APIClient interface { | ||
PutObject(context.Context, *s3.PutObjectInput, ...func(*s3.Options)) (*s3.PutObjectOutput, error) | ||
UploadPart(context.Context, *s3.UploadPartInput, ...func(*s3.Options)) (*s3.UploadPartOutput, error) | ||
CreateMultipartUpload(context.Context, *s3.CreateMultipartUploadInput, ...func(*s3.Options)) (*s3.CreateMultipartUploadOutput, error) | ||
CompleteMultipartUpload(context.Context, *s3.CompleteMultipartUploadInput, ...func(*s3.Options)) (*s3.CompleteMultipartUploadOutput, error) | ||
AbortMultipartUpload(context.Context, *s3.AbortMultipartUploadInput, ...func(*s3.Options)) (*s3.AbortMultipartUploadOutput, error) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
package transfermanager | ||
|
||
import ( | ||
"github.com/aws/aws-sdk-go-v2/aws" | ||
) | ||
|
||
const userAgentKey = "s3-transfer" | ||
|
||
// defaultMaxUploadParts is the maximum allowed number of parts in a multi-part upload | ||
// on Amazon S3. | ||
const defaultMaxUploadParts = 10000 | ||
|
||
// defaultPartSizeBytes is the default part size when transferring objects to/from S3 | ||
const minPartSizeBytes = 1024 * 1024 * 8 | ||
|
||
// defaultMultipartUploadThreshold is the default size threshold in bytes indicating when to use multipart upload. | ||
const defaultMultipartUploadThreshold = 1024 * 1024 * 16 | ||
|
||
// defaultTransferConcurrency is the default number of goroutines to spin up when | ||
// using PutObject(). | ||
const defaultTransferConcurrency = 5 | ||
|
||
// Client provides the API client to make operations call for Amazon Simple | ||
// Storage Service's Transfer Manager | ||
// It is safe to call Client methods concurrently across goroutines. | ||
type Client struct { | ||
options Options | ||
} | ||
|
||
// New returns an initialized Client from the client Options. Provide | ||
// more functional options to further configure the Client | ||
func New(s3Client S3APIClient, opts Options, optFns ...func(*Options)) *Client { | ||
opts.S3 = s3Client | ||
for _, fn := range optFns { | ||
fn(&opts) | ||
} | ||
|
||
resolveConcurrency(&opts) | ||
resolvePartSizeBytes(&opts) | ||
resolveChecksumAlgorithm(&opts) | ||
resolveMultipartUploadThreshold(&opts) | ||
|
||
return &Client{ | ||
options: opts, | ||
} | ||
} | ||
|
||
// NewFromConfig returns a new Client from the provided s3 config | ||
func NewFromConfig(s3Client S3APIClient, cfg aws.Config, optFns ...func(*Options)) *Client { | ||
return New(s3Client, Options{}, optFns...) | ||
} |
Oops, something went wrong.