s3: add support for setting storage class in config and command line

This commit is contained in:
Asko Tamm 2016-09-02 00:27:50 +03:00 committed by Nick Craig-Wood
parent 0caac70994
commit 61665ddd10
2 changed files with 58 additions and 1 deletions

View file

@ -147,6 +147,17 @@ Choose a number from below, or type in your own value
2 / AES256 2 / AES256
\ "AES256" \ "AES256"
server_side_encryption> server_side_encryption>
The storage class to use when storing objects in S3.
Choose a number from below, or type in your own value
1 / Default
\ ""
2 / Standard storage class
\ "STANDARD"
3 / Reduced redundancy storage class
\ "REDUCED_REDUNDANCY"
4 / Standard Infrequent Access storage class
\ "STANDARD_IA"
storage_class>
Remote config Remote config
-------------------- --------------------
[remote] [remote]
@ -217,6 +228,21 @@ credentials. In order of precedence:
If none of these option actually end up providing `rclone` with AWS If none of these option actually end up providing `rclone` with AWS
credentials then S3 interaction will be non-authenticated (see below). credentials then S3 interaction will be non-authenticated (see below).
### Specific options ###
Here are the command line options specific to this cloud storage
system.
#### ----s3-storage-class ####
Storage class to upload new objects with.
Available options include:
- STANDARD - default storage class
- STANDARD_IA - for less frequently accessed data (e.g backups)
- REDUCED_REDUNDANCY (only for noncritical, reproducible data, has lower redundancy)
### Anonymous access to public buckets ### ### Anonymous access to public buckets ###
If you want to use rclone to access a public bucket, configure with a If you want to use rclone to access a public bucket, configure with a

View file

@ -36,6 +36,7 @@ import (
"github.com/ncw/rclone/fs" "github.com/ncw/rclone/fs"
"github.com/ncw/swift" "github.com/ncw/swift"
"github.com/pkg/errors" "github.com/pkg/errors"
"github.com/spf13/pflag"
) )
// Register with Fs // Register with Fs
@ -178,6 +179,22 @@ func init() {
Value: "AES256", Value: "AES256",
Help: "AES256", Help: "AES256",
}}, }},
}, {
Name: "storage_class",
Help: "The storage class to use when storing objects in S3.",
Examples: []fs.OptionExample{{
Value: "",
Help: "Default",
}, {
Value: "STANDARD",
Help: "Standard storage class",
}, {
Value: "REDUCED_REDUNDANCY",
Help: "Reduced redundancy storage class",
}, {
Value: "STANDARD_IA",
Help: "Standard Infrequent Access storage class",
}},
}}, }},
}) })
} }
@ -190,6 +207,12 @@ const (
maxSizeForCopy = 5 * 1024 * 1024 * 1024 // The maximum size of object we can COPY maxSizeForCopy = 5 * 1024 * 1024 * 1024 // The maximum size of object we can COPY
) )
// Globals
var (
// Flags
s3StorageClass = pflag.StringP("s3-storage-class", "", "", "Storage class to use when uploading S3 objects (STANDARD|REDUCED_REDUNDANCY|STANDARD_IA)")
)
// Fs represents a remote s3 server // Fs represents a remote s3 server
type Fs struct { type Fs struct {
name string // the name of the remote name string // the name of the remote
@ -200,6 +223,7 @@ type Fs struct {
root string // root of the bucket - ignore all objects above this root string // root of the bucket - ignore all objects above this
locationConstraint string // location constraint of new buckets locationConstraint string // location constraint of new buckets
sse string // the type of server-side encryption sse string // the type of server-side encryption
storageClass string // storage class
} }
// Object describes a s3 object // Object describes a s3 object
@ -327,7 +351,7 @@ func s3Connection(name string) (*s3.S3, *session.Session, error) {
return c, ses, nil return c, ses, nil
} }
// NewFs contstructs an Fs from the path, bucket:path // NewFs constructs an Fs from the path, bucket:path
func NewFs(name, root string) (fs.Fs, error) { func NewFs(name, root string) (fs.Fs, error) {
bucket, directory, err := s3ParsePath(root) bucket, directory, err := s3ParsePath(root)
if err != nil { if err != nil {
@ -346,6 +370,10 @@ func NewFs(name, root string) (fs.Fs, error) {
root: directory, root: directory,
locationConstraint: fs.ConfigFile.MustValue(name, "location_constraint"), locationConstraint: fs.ConfigFile.MustValue(name, "location_constraint"),
sse: fs.ConfigFile.MustValue(name, "server_side_encryption"), sse: fs.ConfigFile.MustValue(name, "server_side_encryption"),
storageClass: fs.ConfigFile.MustValue(name, "storage_class"),
}
if *s3StorageClass != "" {
f.storageClass = *s3StorageClass
} }
if f.root != "" { if f.root != "" {
f.root += "/" f.root += "/"
@ -867,6 +895,9 @@ func (o *Object) Update(in io.Reader, src fs.ObjectInfo) error {
if o.fs.sse != "" { if o.fs.sse != "" {
req.ServerSideEncryption = &o.fs.sse req.ServerSideEncryption = &o.fs.sse
} }
if o.fs.storageClass != "" {
req.StorageClass = &o.fs.storageClass
}
_, err := uploader.Upload(&req) _, err := uploader.Upload(&req)
if err != nil { if err != nil {
return err return err