rclone/vendor/github.com/aws/aws-sdk-go/service/s3/examples_test.go

2224 lines
55 KiB
Go
Raw Normal View History

// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
package s3_test
import (
"fmt"
2017-07-23 07:51:42 +00:00
"strings"
"time"
"github.com/aws/aws-sdk-go/aws"
2017-07-23 07:51:42 +00:00
"github.com/aws/aws-sdk-go/aws/awserr"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/s3"
)
var _ time.Duration
2017-07-23 07:51:42 +00:00
var _ strings.Reader
var _ aws.Config
2017-07-23 07:51:42 +00:00
func parseTime(layout, value string) *time.Time {
t, err := time.Parse(layout, value)
if err != nil {
panic(err)
}
return &t
}
2017-07-23 07:51:42 +00:00
// To abort a multipart upload
//
// The following example aborts a multipart upload.
func ExampleS3_AbortMultipartUpload_shared00() {
svc := s3.New(session.New())
input := &s3.AbortMultipartUploadInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("bigobject"),
UploadId: aws.String("xadcOB_7YPBOJuoFiQ9cz4P3Pe6FIZwO4f7wN93uHsNBEw97pl5eNwzExg0LAT2dUN91cOmrEQHDsP3WA60CEg--"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.AbortMultipartUpload(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchUpload:
fmt.Println(s3.ErrCodeNoSuchUpload, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To complete multipart upload
//
// The following example completes a multipart upload.
func ExampleS3_CompleteMultipartUpload_shared00() {
svc := s3.New(session.New())
input := &s3.CompleteMultipartUploadInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("bigobject"),
MultipartUpload: &s3.CompletedMultipartUpload{
Parts: []*s3.CompletedPart{
2017-07-23 07:51:42 +00:00
{
ETag: aws.String("\"d8c2eafd90c266e19ab9dcacc479f8af\""),
PartNumber: aws.Int64(1),
},
2017-07-23 07:51:42 +00:00
{
ETag: aws.String("\"d8c2eafd90c266e19ab9dcacc479f8af\""),
PartNumber: aws.Int64(2),
},
},
},
2017-07-23 07:51:42 +00:00
UploadId: aws.String("7YPBOJuoFiQ9cz4P3Pe6FIZwO4f7wN93uHsNBEw97pl5eNwzExg0LAT2dUN91cOmrEQHDsP3WA60CEg--"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.CompleteMultipartUpload(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To copy an object
//
// The following example copies an object from one bucket to another.
func ExampleS3_CopyObject_shared00() {
svc := s3.New(session.New())
input := &s3.CopyObjectInput{
Bucket: aws.String("destinationbucket"),
CopySource: aws.String("/sourcebucket/HappyFacejpg"),
Key: aws.String("HappyFaceCopyjpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.CopyObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeObjectNotInActiveTierError:
fmt.Println(s3.ErrCodeObjectNotInActiveTierError, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To create a bucket in a specific region
//
// The following example creates a bucket. The request specifies an AWS region where
// to create the bucket.
func ExampleS3_CreateBucket_shared00() {
svc := s3.New(session.New())
input := &s3.CreateBucketInput{
Bucket: aws.String("examplebucket"),
CreateBucketConfiguration: &s3.CreateBucketConfiguration{
2017-07-23 07:51:42 +00:00
LocationConstraint: aws.String("eu-west-1"),
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.CreateBucket(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeBucketAlreadyExists:
fmt.Println(s3.ErrCodeBucketAlreadyExists, aerr.Error())
case s3.ErrCodeBucketAlreadyOwnedByYou:
fmt.Println(s3.ErrCodeBucketAlreadyOwnedByYou, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To create a bucket
//
// The following example creates a bucket.
func ExampleS3_CreateBucket_shared01() {
svc := s3.New(session.New())
input := &s3.CreateBucketInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.CreateBucket(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeBucketAlreadyExists:
fmt.Println(s3.ErrCodeBucketAlreadyExists, aerr.Error())
case s3.ErrCodeBucketAlreadyOwnedByYou:
fmt.Println(s3.ErrCodeBucketAlreadyOwnedByYou, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To initiate a multipart upload
//
// The following example initiates a multipart upload.
func ExampleS3_CreateMultipartUpload_shared00() {
svc := s3.New(session.New())
input := &s3.CreateMultipartUploadInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("largeobject"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.CreateMultipartUpload(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete a bucket
//
// The following example deletes the specified bucket.
func ExampleS3_DeleteBucket_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketInput{
Bucket: aws.String("forrandall2"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucket(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete cors configuration on a bucket.
//
// The following example deletes CORS configuration on a bucket.
func ExampleS3_DeleteBucketCors_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketCorsInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucketCors(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete lifecycle configuration on a bucket.
//
// The following example deletes lifecycle configuration on a bucket.
func ExampleS3_DeleteBucketLifecycle_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketLifecycleInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucketLifecycle(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete bucket policy
//
// The following example deletes bucket policy on the specified bucket.
func ExampleS3_DeleteBucketPolicy_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketPolicyInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucketPolicy(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete bucket replication configuration
//
// The following example deletes replication configuration set on bucket.
func ExampleS3_DeleteBucketReplication_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketReplicationInput{
Bucket: aws.String("example"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucketReplication(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete bucket tags
//
// The following example deletes bucket tags.
func ExampleS3_DeleteBucketTagging_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketTaggingInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucketTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete bucket website configuration
//
// The following example deletes bucket website configuration.
func ExampleS3_DeleteBucketWebsite_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteBucketWebsiteInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteBucketWebsite(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete an object (from a non-versioned bucket)
//
// The following example deletes an object from a non-versioned bucket.
func ExampleS3_DeleteObject_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteObjectInput{
Bucket: aws.String("ExampleBucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete an object
//
// The following example deletes an object from an S3 bucket.
func ExampleS3_DeleteObject_shared01() {
svc := s3.New(session.New())
input := &s3.DeleteObjectInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("objectkey.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To remove tag set from an object version
//
// The following example removes tag set associated with the specified object version.
// The request specifies both the object key and object version.
func ExampleS3_DeleteObjectTagging_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteObjectTaggingInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
VersionId: aws.String("ydlaNkwWm0SfKJR.T1b1fIdPRbldTYRI"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteObjectTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To remove tag set from an object
//
// The following example removes tag set associated with the specified object. If the
// bucket is versioning enabled, the operation removes tag set from the latest object
// version.
func ExampleS3_DeleteObjectTagging_shared01() {
svc := s3.New(session.New())
input := &s3.DeleteObjectTaggingInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteObjectTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete multiple object versions from a versioned bucket
//
// The following example deletes objects from a bucket. The request specifies object
// versions. S3 deletes specific object versions and returns the key and versions of
// deleted objects in the response.
func ExampleS3_DeleteObjects_shared00() {
svc := s3.New(session.New())
input := &s3.DeleteObjectsInput{
Bucket: aws.String("examplebucket"),
Delete: &s3.Delete{
Objects: []*s3.ObjectIdentifier{
{
Key: aws.String("HappyFace.jpg"),
VersionId: aws.String("2LWg7lQLnY41.maGB5Z6SWW.dcq0vx7b"),
},
{
Key: aws.String("HappyFace.jpg"),
VersionId: aws.String("yoz3HB.ZhCS_tKVEmIOr7qYyyAaZSKVd"),
},
},
2017-07-23 07:51:42 +00:00
Quiet: aws.Bool(false),
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteObjects(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To delete multiple objects from a versioned bucket
//
// The following example deletes objects from a bucket. The bucket is versioned, and
// the request does not specify the object version to delete. In this case, all versions
// remain in the bucket and S3 adds a delete marker.
func ExampleS3_DeleteObjects_shared01() {
svc := s3.New(session.New())
input := &s3.DeleteObjectsInput{
Bucket: aws.String("examplebucket"),
Delete: &s3.Delete{
Objects: []*s3.ObjectIdentifier{
{
Key: aws.String("objectkey1"),
},
{
Key: aws.String("objectkey2"),
},
},
Quiet: aws.Bool(false),
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.DeleteObjects(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get cors configuration set on a bucket
//
// The following example returns cross-origin resource sharing (CORS) configuration
// set on a bucket.
func ExampleS3_GetBucketCors_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketCorsInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketCors(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get a bucket acl
//
// The following example gets ACL on the specified bucket.
func ExampleS3_GetBucketLifecycle_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketLifecycleInput{
Bucket: aws.String("acl1"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketLifecycle(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get lifecycle configuration on a bucket
//
// The following example retrieves lifecycle configuration on set on a bucket.
func ExampleS3_GetBucketLifecycleConfiguration_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketLifecycleConfigurationInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketLifecycleConfiguration(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get bucket location
//
// The following example returns bucket location.
func ExampleS3_GetBucketLocation_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketLocationInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketLocation(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get notification configuration set on a bucket
//
// The following example returns notification configuration set on a bucket.
func ExampleS3_GetBucketNotification_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketNotificationConfigurationRequest{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketNotification(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get notification configuration set on a bucket
//
// The following example returns notification configuration set on a bucket.
func ExampleS3_GetBucketNotification_shared01() {
svc := s3.New(session.New())
input := &s3.GetBucketNotificationConfigurationRequest{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketNotification(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get bucket policy
//
// The following example returns bucket policy associated with a bucket.
func ExampleS3_GetBucketPolicy_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketPolicyInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketPolicy(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get replication configuration set on a bucket
//
// The following example returns replication configuration set on a bucket.
func ExampleS3_GetBucketReplication_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketReplicationInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketReplication(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get bucket versioning configuration
//
// The following example retrieves bucket versioning configuration.
func ExampleS3_GetBucketRequestPayment_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketRequestPaymentInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketRequestPayment(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get tag set associated with a bucket
//
// The following example returns tag set associated with a bucket
func ExampleS3_GetBucketTagging_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketTaggingInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get bucket versioning configuration
//
// The following example retrieves bucket versioning configuration.
func ExampleS3_GetBucketVersioning_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketVersioningInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketVersioning(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get bucket website configuration
//
// The following example retrieves website configuration of a bucket.
func ExampleS3_GetBucketWebsite_shared00() {
svc := s3.New(session.New())
input := &s3.GetBucketWebsiteInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetBucketWebsite(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve an object
//
// The following example retrieves an object for an S3 bucket.
func ExampleS3_GetObject_shared00() {
svc := s3.New(session.New())
input := &s3.GetObjectInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchKey:
fmt.Println(s3.ErrCodeNoSuchKey, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve a byte range of an object
//
// The following example retrieves an object for an S3 bucket. The request specifies
// the range header to retrieve a specific byte range.
func ExampleS3_GetObject_shared01() {
svc := s3.New(session.New())
input := &s3.GetObjectInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("SampleFile.txt"),
Range: aws.String("bytes=0-9"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchKey:
fmt.Println(s3.ErrCodeNoSuchKey, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve object ACL
//
// The following example retrieves access control list (ACL) of an object.
func ExampleS3_GetObjectAcl_shared00() {
svc := s3.New(session.New())
input := &s3.GetObjectAclInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetObjectAcl(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchKey:
fmt.Println(s3.ErrCodeNoSuchKey, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve tag set of an object
//
// The following example retrieves tag set of an object.
func ExampleS3_GetObjectTagging_shared00() {
svc := s3.New(session.New())
input := &s3.GetObjectTaggingInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetObjectTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve tag set of a specific object version
//
// The following example retrieves tag set of an object. The request specifies object
// version.
func ExampleS3_GetObjectTagging_shared01() {
svc := s3.New(session.New())
input := &s3.GetObjectTaggingInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("exampleobject"),
VersionId: aws.String("ydlaNkwWm0SfKJR.T1b1fIdPRbldTYRI"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetObjectTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve torrent files for an object
//
// The following example retrieves torrent files of an object.
func ExampleS3_GetObjectTorrent_shared00() {
svc := s3.New(session.New())
input := &s3.GetObjectTorrentInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.GetObjectTorrent(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To determine if bucket exists
//
// This operation checks to see if a bucket exists.
func ExampleS3_HeadBucket_shared00() {
svc := s3.New(session.New())
input := &s3.HeadBucketInput{
Bucket: aws.String("acl1"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.HeadBucket(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchBucket:
fmt.Println(s3.ErrCodeNoSuchBucket, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To retrieve metadata of an object without returning the object itself
//
// The following example retrieves an object metadata.
func ExampleS3_HeadObject_shared00() {
svc := s3.New(session.New())
input := &s3.HeadObjectInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.HeadObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To list object versions
//
// The following example return versions of an object with specific key name prefix.
// The request limits the number of items returned to two. If there are are more than
// two object version, S3 returns NextToken in the response. You can specify this token
// value in your next request to fetch next set of object versions.
func ExampleS3_ListBuckets_shared00() {
svc := s3.New(session.New())
input := &s3.ListBucketsInput{}
2017-07-23 07:51:42 +00:00
result, err := svc.ListBuckets(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To list in-progress multipart uploads on a bucket
//
// The following example lists in-progress multipart uploads on a specific bucket.
func ExampleS3_ListMultipartUploads_shared00() {
svc := s3.New(session.New())
input := &s3.ListMultipartUploadsInput{
Bucket: aws.String("examplebucket"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.ListMultipartUploads(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// List next set of multipart uploads when previous result is truncated
//
// The following example specifies the upload-id-marker and key-marker from previous
// truncated response to retrieve next setup of multipart uploads.
func ExampleS3_ListMultipartUploads_shared01() {
svc := s3.New(session.New())
input := &s3.ListMultipartUploadsInput{
Bucket: aws.String("examplebucket"),
KeyMarker: aws.String("nextkeyfrompreviousresponse"),
MaxUploads: aws.Int64(2),
UploadIdMarker: aws.String("valuefrompreviousresponse"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.ListMultipartUploads(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To list object versions
//
// The following example return versions of an object with specific key name prefix.
// The request limits the number of items returned to two. If there are are more than
// two object version, S3 returns NextToken in the response. You can specify this token
// value in your next request to fetch next set of object versions.
func ExampleS3_ListObjectVersions_shared00() {
svc := s3.New(session.New())
input := &s3.ListObjectVersionsInput{
Bucket: aws.String("examplebucket"),
Prefix: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.ListObjectVersions(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To list objects in a bucket
//
// The following example list two objects in a bucket.
func ExampleS3_ListObjects_shared00() {
svc := s3.New(session.New())
input := &s3.ListObjectsInput{
Bucket: aws.String("examplebucket"),
MaxKeys: aws.Int64(2),
}
2017-07-23 07:51:42 +00:00
result, err := svc.ListObjects(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchBucket:
fmt.Println(s3.ErrCodeNoSuchBucket, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To get object list
//
// The following example retrieves object list. The request specifies max keys to limit
// response to include only 2 object keys.
func ExampleS3_ListObjectsV2_shared00() {
svc := s3.New(session.New())
input := &s3.ListObjectsV2Input{
Bucket: aws.String("examplebucket"),
MaxKeys: aws.Int64(2),
}
2017-07-23 07:51:42 +00:00
result, err := svc.ListObjectsV2(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchBucket:
fmt.Println(s3.ErrCodeNoSuchBucket, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To list parts of a multipart upload.
//
// The following example lists parts uploaded for a specific multipart upload.
func ExampleS3_ListParts_shared00() {
svc := s3.New(session.New())
input := &s3.ListPartsInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("bigobject"),
UploadId: aws.String("example7YPBOJuoFiQ9cz4P3Pe6FIZwO4f7wN93uHsNBEw97pl5eNwzExg0LAT2dUN91cOmrEQHDsP3WA60CEg--"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.ListParts(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Put bucket acl
//
// The following example replaces existing ACL on a bucket. The ACL grants the bucket
// owner (specified using the owner ID) and write permission to the LogDelivery group.
// Because this is a replace operation, you must specify all the grants in your request.
// To incrementally add or remove ACL grants, you might use the console.
func ExampleS3_PutBucketAcl_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketAclInput{
Bucket: aws.String("examplebucket"),
GrantFullControl: aws.String("id=examplee7a2f25102679df27bb0ae12b3f85be6f290b936c4393484"),
GrantWrite: aws.String("uri=http://acs.amazonaws.com/groups/s3/LogDelivery"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketAcl(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To set cors configuration on a bucket.
//
// The following example enables PUT, POST, and DELETE requests from www.example.com,
// and enables GET requests from any domain.
func ExampleS3_PutBucketCors_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketCorsInput{
Bucket: aws.String(""),
CORSConfiguration: &s3.CORSConfiguration{
CORSRules: []*s3.CORSRule{
{
AllowedHeaders: []*string{
aws.String("*"),
},
AllowedMethods: []*string{
aws.String("PUT"),
aws.String("POST"),
aws.String("DELETE"),
},
2017-07-23 07:51:42 +00:00
AllowedOrigins: []*string{
aws.String("http://www.example.com"),
},
ExposeHeaders: []*string{
aws.String("x-amz-server-side-encryption"),
},
MaxAgeSeconds: aws.Int64(3000),
},
{
AllowedHeaders: []*string{
aws.String("Authorization"),
},
AllowedMethods: []*string{
aws.String("GET"),
},
AllowedOrigins: []*string{
aws.String("*"),
},
MaxAgeSeconds: aws.Int64(3000),
},
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketCors(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Put bucket lifecycle
//
// The following example replaces existing lifecycle configuration, if any, on the specified
// bucket.
func ExampleS3_PutBucketLifecycleConfiguration_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketLifecycleConfigurationInput{
Bucket: aws.String("examplebucket"),
LifecycleConfiguration: &s3.BucketLifecycleConfiguration{
Rules: []*s3.LifecycleRule{
{
ID: aws.String("TestOnly"),
Status: aws.String("Enabled"),
Transitions: []*s3.Transition{
{
Days: aws.Int64(365),
StorageClass: aws.String("GLACIER"),
},
},
},
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketLifecycleConfiguration(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set logging configuration for a bucket
//
// The following example sets logging policy on a bucket. For the Log Delivery group
// to deliver logs to the destination bucket, it needs permission for the READ_ACP action
// which the policy grants.
func ExampleS3_PutBucketLogging_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketLoggingInput{
Bucket: aws.String("sourcebucket"),
BucketLoggingStatus: &s3.BucketLoggingStatus{
LoggingEnabled: &s3.LoggingEnabled{
TargetBucket: aws.String("targetbucket"),
TargetGrants: []*s3.TargetGrant{
{
Permission: aws.String("READ"),
},
},
2017-07-23 07:51:42 +00:00
TargetPrefix: aws.String("MyBucketLogs/"),
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketLogging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set notification configuration for a bucket
//
// The following example sets notification configuration on a bucket to publish the
// object created events to an SNS topic.
func ExampleS3_PutBucketNotificationConfiguration_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketNotificationConfigurationInput{
Bucket: aws.String("examplebucket"),
NotificationConfiguration: &s3.NotificationConfiguration{
TopicConfigurations: []*s3.TopicConfiguration{
{
Events: []*string{
aws.String("s3:ObjectCreated:*"),
},
TopicArn: aws.String("arn:aws:sns:us-west-2:123456789012:s3-notification-topic"),
},
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketNotificationConfiguration(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set bucket policy
//
// The following example sets a permission policy on a bucket.
func ExampleS3_PutBucketPolicy_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketPolicyInput{
Bucket: aws.String("examplebucket"),
Policy: aws.String("{\"Version\": \"2012-10-17\", \"Statement\": [{ \"Sid\": \"id-1\",\"Effect\": \"Allow\",\"Principal\": {\"AWS\": \"arn:aws:iam::123456789012:root\"}, \"Action\": [ \"s3:PutObject\",\"s3:PutObjectAcl\"], \"Resource\": [\"arn:aws:s3:::acl3/*\" ] } ]}"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketPolicy(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set replication configuration on a bucket
//
// The following example sets replication configuration on a bucket.
func ExampleS3_PutBucketReplication_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketReplicationInput{
Bucket: aws.String("examplebucket"),
ReplicationConfiguration: &s3.ReplicationConfiguration{
Role: aws.String("arn:aws:iam::123456789012:role/examplerole"),
Rules: []*s3.ReplicationRule{
{
Prefix: aws.String(""),
Status: aws.String("Enabled"),
},
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketReplication(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set request payment configuration on a bucket.
//
// The following example sets request payment configuration on a bucket so that person
// requesting the download is charged.
func ExampleS3_PutBucketRequestPayment_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketRequestPaymentInput{
Bucket: aws.String("examplebucket"),
RequestPaymentConfiguration: &s3.RequestPaymentConfiguration{
Payer: aws.String("Requester"),
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketRequestPayment(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set tags on a bucket
//
// The following example sets tags on a bucket. Any existing tags are replaced.
func ExampleS3_PutBucketTagging_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketTaggingInput{
Bucket: aws.String("examplebucket"),
Tagging: &s3.Tagging{
TagSet: []*s3.Tag{
{
Key: aws.String("Key1"),
Value: aws.String("Value1"),
},
2017-07-23 07:51:42 +00:00
{
Key: aws.String("Key2"),
Value: aws.String("Value2"),
},
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set versioning configuration on a bucket
//
// The following example sets versioning configuration on bucket. The configuration
// enables versioning on the bucket.
func ExampleS3_PutBucketVersioning_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketVersioningInput{
Bucket: aws.String("examplebucket"),
VersioningConfiguration: &s3.VersioningConfiguration{
MFADelete: aws.String("Disabled"),
Status: aws.String("Enabled"),
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketVersioning(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// Set website configuration on a bucket
//
// The following example adds website configuration to a bucket.
func ExampleS3_PutBucketWebsite_shared00() {
svc := s3.New(session.New())
input := &s3.PutBucketWebsiteInput{
Bucket: aws.String("examplebucket"),
WebsiteConfiguration: &s3.WebsiteConfiguration{
ErrorDocument: &s3.ErrorDocument{
Key: aws.String("error.html"),
},
2017-07-23 07:51:42 +00:00
IndexDocument: &s3.IndexDocument{
Suffix: aws.String("index.html"),
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutBucketWebsite(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload an object and specify server-side encryption and object tags
//
// The following example uploads and object. The request specifies the optional server-side
// encryption option. The request also specifies optional object tags. If the bucket
// is versioning enabled, S3 returns version ID in response.
func ExampleS3_PutObject_shared00() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
Body: aws.ReadSeekCloser(strings.NewReader("filetoupload")),
Bucket: aws.String("examplebucket"),
Key: aws.String("exampleobject"),
ServerSideEncryption: aws.String("AES256"),
Tagging: aws.String("key1=value1&key2=value2"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload an object and specify canned ACL.
//
// The following example uploads and object. The request specifies optional canned ACL
// (access control list) to all READ access to authenticated users. If the bucket is
// versioning enabled, S3 returns version ID in response.
func ExampleS3_PutObject_shared01() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
ACL: aws.String("authenticated-read"),
Body: aws.ReadSeekCloser(strings.NewReader("filetoupload")),
Bucket: aws.String("examplebucket"),
Key: aws.String("exampleobject"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload an object
//
// The following example uploads an object to a versioning-enabled bucket. The source
// file is specified using Windows file syntax. S3 returns VersionId of the newly created
// object.
func ExampleS3_PutObject_shared02() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
Body: aws.ReadSeekCloser(strings.NewReader("HappyFace.jpg")),
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To create an object.
//
// The following example creates an object. If the bucket is versioning enabled, S3
// returns version ID in response.
func ExampleS3_PutObject_shared03() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
Body: aws.ReadSeekCloser(strings.NewReader("filetoupload")),
Bucket: aws.String("examplebucket"),
Key: aws.String("objectkey"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload an object and specify optional tags
//
// The following example uploads an object. The request specifies optional object tags.
// The bucket is versioned, therefore S3 returns version ID of the newly created object.
func ExampleS3_PutObject_shared04() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
Body: aws.ReadSeekCloser(strings.NewReader("c:\\HappyFace.jpg")),
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
Tagging: aws.String("key1=value1&key2=value2"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload object and specify user-defined metadata
//
// The following example creates an object. The request also specifies optional metadata.
// If the bucket is versioning enabled, S3 returns version ID in response.
func ExampleS3_PutObject_shared05() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
Body: aws.ReadSeekCloser(strings.NewReader("filetoupload")),
Bucket: aws.String("examplebucket"),
Key: aws.String("exampleobject"),
Metadata: map[string]*string{
"metadata1": aws.String("value1"),
"metadata2": aws.String("value2"),
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload an object (specify optional headers)
//
// The following example uploads an object. The request specifies optional request headers
// to directs S3 to use specific storage class and use server-side encryption.
func ExampleS3_PutObject_shared06() {
svc := s3.New(session.New())
input := &s3.PutObjectInput{
Body: aws.ReadSeekCloser(strings.NewReader("HappyFace.jpg")),
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
ServerSideEncryption: aws.String("AES256"),
StorageClass: aws.String("STANDARD_IA"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To grant permissions using object ACL
//
// The following example adds grants to an object ACL. The first permission grants user1
// and user2 FULL_CONTROL and the AllUsers group READ permission.
func ExampleS3_PutObjectAcl_shared00() {
svc := s3.New(session.New())
input := &s3.PutObjectAclInput{
AccessControlPolicy: &s3.AccessControlPolicy{},
Bucket: aws.String("examplebucket"),
GrantFullControl: aws.String("emailaddress=user1@example.com,emailaddress=user2@example.com"),
GrantRead: aws.String("uri=http://acs.amazonaws.com/groups/global/AllUsers"),
Key: aws.String("HappyFace.jpg"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObjectAcl(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeNoSuchKey:
fmt.Println(s3.ErrCodeNoSuchKey, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To add tags to an existing object
//
// The following example adds tags to an existing object.
func ExampleS3_PutObjectTagging_shared00() {
svc := s3.New(session.New())
input := &s3.PutObjectTaggingInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("HappyFace.jpg"),
Tagging: &s3.Tagging{
TagSet: []*s3.Tag{
{
Key: aws.String("Key3"),
Value: aws.String("Value3"),
},
{
Key: aws.String("Key4"),
Value: aws.String("Value4"),
},
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.PutObjectTagging(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To restore an archived object
//
// The following example restores for one day an archived copy of an object back into
// Amazon S3 bucket.
func ExampleS3_RestoreObject_shared00() {
svc := s3.New(session.New())
input := &s3.RestoreObjectInput{
Bucket: aws.String("examplebucket"),
Key: aws.String("archivedobjectkey"),
RestoreRequest: &s3.RestoreRequest{
2017-07-23 07:51:42 +00:00
Days: aws.Int64(1),
GlacierJobParameters: &s3.GlacierJobParameters{
2017-07-23 07:51:42 +00:00
Tier: aws.String("Expedited"),
},
},
}
2017-07-23 07:51:42 +00:00
result, err := svc.RestoreObject(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
case s3.ErrCodeObjectAlreadyInActiveTierError:
fmt.Println(s3.ErrCodeObjectAlreadyInActiveTierError, aerr.Error())
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload a part
//
// The following example uploads part 1 of a multipart upload. The example specifies
// a file name for the part data. The Upload ID is same that is returned by the initiate
// multipart upload.
func ExampleS3_UploadPart_shared00() {
svc := s3.New(session.New())
input := &s3.UploadPartInput{
Body: aws.ReadSeekCloser(strings.NewReader("fileToUpload")),
Bucket: aws.String("examplebucket"),
Key: aws.String("examplelargeobject"),
PartNumber: aws.Int64(1),
UploadId: aws.String("xadcOB_7YPBOJuoFiQ9cz4P3Pe6FIZwO4f7wN93uHsNBEw97pl5eNwzExg0LAT2dUN91cOmrEQHDsP3WA60CEg--"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.UploadPart(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload a part by copying byte range from an existing object as data source
//
// The following example uploads a part of a multipart upload by copying a specified
// byte range from an existing object as data source.
func ExampleS3_UploadPartCopy_shared00() {
svc := s3.New(session.New())
input := &s3.UploadPartCopyInput{
Bucket: aws.String("examplebucket"),
CopySource: aws.String("/bucketname/sourceobjectkey"),
CopySourceRange: aws.String("bytes=1-100000"),
Key: aws.String("examplelargeobject"),
PartNumber: aws.Int64(2),
UploadId: aws.String("exampleuoh_10OhKhT7YukE9bjzTPRiuaCotmZM_pFngJFir9OZNrSr5cWa3cq3LZSUsfjI4FI7PkP91We7Nrw--"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.UploadPartCopy(input)
if err != nil {
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
fmt.Println(result)
}
2017-07-23 07:51:42 +00:00
// To upload a part by copying data from an existing object as data source
//
// The following example uploads a part of a multipart upload by copying data from an
// existing object as data source.
func ExampleS3_UploadPartCopy_shared01() {
svc := s3.New(session.New())
input := &s3.UploadPartCopyInput{
Bucket: aws.String("examplebucket"),
CopySource: aws.String("bucketname/sourceobjectkey"),
Key: aws.String("examplelargeobject"),
PartNumber: aws.Int64(1),
UploadId: aws.String("exampleuoh_10OhKhT7YukE9bjzTPRiuaCotmZM_pFngJFir9OZNrSr5cWa3cq3LZSUsfjI4FI7PkP91We7Nrw--"),
}
2017-07-23 07:51:42 +00:00
result, err := svc.UploadPartCopy(input)
if err != nil {
2017-07-23 07:51:42 +00:00
if aerr, ok := err.(awserr.Error); ok {
switch aerr.Code() {
default:
fmt.Println(aerr.Error())
}
} else {
// Print the error, cast err to awserr.Error to get the Code and
// Message from an error.
fmt.Println(err.Error())
}
return
}
2017-07-23 07:51:42 +00:00
fmt.Println(result)
}