forked from TrueCloudLab/rclone
s3: add support for setting storage class in config and command line
This commit is contained in:
parent
0caac70994
commit
61665ddd10
2 changed files with 58 additions and 1 deletions
|
@ -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
|
||||||
|
|
33
s3/s3.go
33
s3/s3.go
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue