forked from TrueCloudLab/rclone
s3: add in config for all the supported S3 providers #2140
These are AWS, Ceph, Dreamhost, IBM COS S3, Minio, Wasabi and Other. This configures endpoints where known and makes sure config doesn't appear where it isn't valid where possible.
This commit is contained in:
parent
8c3740c2c5
commit
dc247d21ff
2 changed files with 542 additions and 516 deletions
900
backend/s3/s3.go
900
backend/s3/s3.go
|
@ -54,443 +54,471 @@ func init() {
|
||||||
Description: "Amazon S3 Compliant Storage Providers (AWS, Ceph, Dreamhost, IBM COS, Minio)",
|
Description: "Amazon S3 Compliant Storage Providers (AWS, Ceph, Dreamhost, IBM COS, Minio)",
|
||||||
NewFs: NewFs,
|
NewFs: NewFs,
|
||||||
Options: []fs.Option{{
|
Options: []fs.Option{{
|
||||||
Name: "Provider",
|
Name: fs.ConfigProvider,
|
||||||
Help: "Choose the S3 provider.",
|
Help: "Choose your S3 provider.",
|
||||||
Examples: []fs.OptionExample{
|
Examples: []fs.OptionExample{{
|
||||||
{
|
Value: "AWS",
|
||||||
Value: "AWS",
|
Help: "Amazon Web Services (AWS) S3",
|
||||||
Help: "Choose this option to configure Storage to AWS S3",
|
}, {
|
||||||
},
|
Value: "Ceph",
|
||||||
{
|
Help: "Ceph Object Storage",
|
||||||
Value: "Ceph",
|
}, {
|
||||||
Help: "Choose this option to configure Storage to Ceph Systems",
|
Value: "DigitalOcean",
|
||||||
},
|
Help: "Digital Ocean Spaces",
|
||||||
{
|
}, {
|
||||||
Value: "Dreamhost",
|
Value: "Dreamhost",
|
||||||
Help: " Choose this option to configure Storage to Dreamhost",
|
Help: "Dreamhost DreamObjects",
|
||||||
},
|
}, {
|
||||||
{
|
Value: "IBMCOS",
|
||||||
Value: "IBMCOS",
|
Help: "IBM COS S3",
|
||||||
Help: "Choose this option to the configure Storage to IBM COS S3",
|
}, {
|
||||||
},
|
Value: "Minio",
|
||||||
{
|
Help: "Minio Object Storage",
|
||||||
Value: "Minio",
|
}, {
|
||||||
Help: "Choose this option to the configure Storage to Minio",
|
Value: "Wasabi",
|
||||||
},
|
Help: "Wasabi Object Storage",
|
||||||
{
|
}, {
|
||||||
Value: "Other",
|
Value: "Other",
|
||||||
Help: "Choose this option to the configure any other S3 Storage",
|
Help: "Any other S3 compatible provider",
|
||||||
},
|
}},
|
||||||
},
|
}, {
|
||||||
|
Name: "env_auth",
|
||||||
|
Help: "Get AWS credentials from runtime (environment variables or EC2/ECS meta data if no env vars). Only applies if access_key_id and secret_access_key is blank.",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "false",
|
||||||
|
Help: "Enter AWS credentials in the next step",
|
||||||
|
}, {
|
||||||
|
Value: "true",
|
||||||
|
Help: "Get AWS credentials from the environment (env vars or IAM)",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "access_key_id",
|
||||||
|
Help: "AWS Access Key ID - leave blank for anonymous access or runtime credentials.",
|
||||||
|
}, {
|
||||||
|
Name: "secret_access_key",
|
||||||
|
Help: "AWS Secret Access Key (password) - leave blank for anonymous access or runtime credentials.",
|
||||||
|
}, {
|
||||||
|
Name: "region",
|
||||||
|
Help: "Region to connect to.",
|
||||||
|
Provider: "AWS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "us-east-1",
|
||||||
|
Help: "The default endpoint - a good choice if you are unsure.\nUS Region, Northern Virginia or Pacific Northwest.\nLeave location constraint empty.",
|
||||||
|
}, {
|
||||||
|
Value: "us-east-2",
|
||||||
|
Help: "US East (Ohio) Region\nNeeds location constraint us-east-2.",
|
||||||
|
}, {
|
||||||
|
Value: "us-west-2",
|
||||||
|
Help: "US West (Oregon) Region\nNeeds location constraint us-west-2.",
|
||||||
|
}, {
|
||||||
|
Value: "us-west-1",
|
||||||
|
Help: "US West (Northern California) Region\nNeeds location constraint us-west-1.",
|
||||||
|
}, {
|
||||||
|
Value: "ca-central-1",
|
||||||
|
Help: "Canada (Central) Region\nNeeds location constraint ca-central-1.",
|
||||||
|
}, {
|
||||||
|
Value: "eu-west-1",
|
||||||
|
Help: "EU (Ireland) Region\nNeeds location constraint EU or eu-west-1.",
|
||||||
|
}, {
|
||||||
|
Value: "eu-west-2",
|
||||||
|
Help: "EU (London) Region\nNeeds location constraint eu-west-2.",
|
||||||
|
}, {
|
||||||
|
Value: "eu-central-1",
|
||||||
|
Help: "EU (Frankfurt) Region\nNeeds location constraint eu-central-1.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-southeast-1",
|
||||||
|
Help: "Asia Pacific (Singapore) Region\nNeeds location constraint ap-southeast-1.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-southeast-2",
|
||||||
|
Help: "Asia Pacific (Sydney) Region\nNeeds location constraint ap-southeast-2.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-northeast-1",
|
||||||
|
Help: "Asia Pacific (Tokyo) Region\nNeeds location constraint ap-northeast-1.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-northeast-2",
|
||||||
|
Help: "Asia Pacific (Seoul)\nNeeds location constraint ap-northeast-2.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-south-1",
|
||||||
|
Help: "Asia Pacific (Mumbai)\nNeeds location constraint ap-south-1.",
|
||||||
|
}, {
|
||||||
|
Value: "sa-east-1",
|
||||||
|
Help: "South America (Sao Paulo) Region\nNeeds location constraint sa-east-1.",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "region",
|
||||||
|
Help: "Region to connect to. Leave blank if you are using an S3 clone and you don't have a region.",
|
||||||
|
Provider: "!AWS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "",
|
||||||
|
Help: "Use this if unsure. Will use v4 signatures and an empty region.",
|
||||||
|
}, {
|
||||||
|
Value: "other-v2-signature",
|
||||||
|
Help: "Use this only if v4 signatures don't work, eg pre Jewel/v10 CEPH.",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "endpoint",
|
||||||
|
Help: "Endpoint for S3 API.\nLeave blank if using AWS to use the default endpoint for the region.",
|
||||||
|
Provider: "AWS",
|
||||||
|
}, {
|
||||||
|
Name: "endpoint",
|
||||||
|
Help: "Endpoint for IBM COS S3 API.\nSpecify if using an IBM COS On Premise.",
|
||||||
|
Provider: "IBMCOS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "s3-api.us-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "US Cross Region Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.dal.us-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "US Cross Region Dallas Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.wdc-us-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "US Cross Region Washington DC Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.sjc-us-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "US Cross Region San Jose Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.us-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "US Cross Region Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.dal-us-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "US Cross Region Dallas Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.wdc-us-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "US Cross Region Washington DC Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3-api.sjc-us-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "US Cross Region San Jose Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.us-east.objectstorage.softlayer.net",
|
||||||
|
Help: "US Region East Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.us-east.objectstorage.service.networklayer.com",
|
||||||
|
Help: "US Region East Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.us-south.objectstorage.softlayer.net",
|
||||||
|
Help: "US Region South Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.us-south.objectstorage.service.networklayer.com",
|
||||||
|
Help: "US Region South Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.eu-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "EU Cross Region Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.fra-eu-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "EU Cross Region Frankfurt Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.mil-eu-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "EU Cross Region Milan Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.ams-eu-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "EU Cross Region Amsterdam Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.eu-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "EU Cross Region Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.fra-eu-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "EU Cross Region Frankfurt Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.mil-eu-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "EU Cross Region Milan Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.ams-eu-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "EU Cross Region Amsterdam Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.eu-gb.objectstorage.softlayer.net",
|
||||||
|
Help: "Great Britan Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.eu-gb.objectstorage.service.networklayer.com",
|
||||||
|
Help: "Great Britan Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.ap-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "APAC Cross Regional Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.tok-ap-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "APAC Cross Regional Tokyo Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.hkg-ap-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "APAC Cross Regional HongKong Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.seo-ap-geo.objectstorage.softlayer.net",
|
||||||
|
Help: "APAC Cross Regional Seoul Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.ap-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "APAC Cross Regional Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.tok-ap-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "APAC Cross Regional Tokyo Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.hkg-ap-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "APAC Cross Regional HongKong Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.seo-ap-geo.objectstorage.service.networklayer.com",
|
||||||
|
Help: "APAC Cross Regional Seoul Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.mel01.objectstorage.softlayer.net",
|
||||||
|
Help: "Melbourne Single Site Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.mel01.objectstorage.service.networklayer.com",
|
||||||
|
Help: "Melbourne Single Site Private Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.tor01.objectstorage.softlayer.net",
|
||||||
|
Help: "Toronto Single Site Endpoint",
|
||||||
|
}, {
|
||||||
|
Value: "s3.tor01.objectstorage.service.networklayer.com",
|
||||||
|
Help: "Toronto Single Site Private Endpoint",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "endpoint",
|
||||||
|
Help: "Endpoint for S3 API.\nRequired when using an S3 clone.",
|
||||||
|
Provider: "!AWS,IBMCOS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "objects-us-west-1.dream.io",
|
||||||
|
Help: "Dream Objects endpoint",
|
||||||
|
Provider: "Dreamhost",
|
||||||
|
}, {
|
||||||
|
Value: "nyc3.digitaloceanspaces.com",
|
||||||
|
Help: "Digital Ocean Spaces New York 3",
|
||||||
|
Provider: "DigitalOcean",
|
||||||
|
}, {
|
||||||
|
Value: "ams3.digitaloceanspaces.com",
|
||||||
|
Help: "Digital Ocean Spaces Amsterdam 3",
|
||||||
|
Provider: "DigitalOcean",
|
||||||
|
}, {
|
||||||
|
Value: "sgp1.digitaloceanspaces.com",
|
||||||
|
Help: "Digital Ocean Spaces Singapore 1",
|
||||||
|
Provider: "DigitalOcean",
|
||||||
|
}, {
|
||||||
|
Value: "s3.wasabisys.com",
|
||||||
|
Help: "Wasabi Object Storage",
|
||||||
|
Provider: "Wasabi",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "location_constraint",
|
||||||
|
Help: "Location constraint - must be set to match the Region. Used when creating buckets only.",
|
||||||
|
Provider: "AWS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "",
|
||||||
|
Help: "Empty for US Region, Northern Virginia or Pacific Northwest.",
|
||||||
|
}, {
|
||||||
|
Value: "us-east-2",
|
||||||
|
Help: "US East (Ohio) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "us-west-2",
|
||||||
|
Help: "US West (Oregon) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "us-west-1",
|
||||||
|
Help: "US West (Northern California) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "ca-central-1",
|
||||||
|
Help: "Canada (Central) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "eu-west-1",
|
||||||
|
Help: "EU (Ireland) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "eu-west-2",
|
||||||
|
Help: "EU (London) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "EU",
|
||||||
|
Help: "EU Region.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-southeast-1",
|
||||||
|
Help: "Asia Pacific (Singapore) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-southeast-2",
|
||||||
|
Help: "Asia Pacific (Sydney) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-northeast-1",
|
||||||
|
Help: "Asia Pacific (Tokyo) Region.",
|
||||||
|
}, {
|
||||||
|
Value: "ap-northeast-2",
|
||||||
|
Help: "Asia Pacific (Seoul)",
|
||||||
|
}, {
|
||||||
|
Value: "ap-south-1",
|
||||||
|
Help: "Asia Pacific (Mumbai)",
|
||||||
|
}, {
|
||||||
|
Value: "sa-east-1",
|
||||||
|
Help: "South America (Sao Paulo) Region.",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "location_constraint",
|
||||||
|
Help: "Location constraint - must match endpoint when using IBM Cloud Public. For on-prem COS, do not make a selection from this list, hit enter",
|
||||||
|
Provider: "IBMCOS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "us-standard",
|
||||||
|
Help: "US Cross Region Standard",
|
||||||
|
}, {
|
||||||
|
Value: "us-vault",
|
||||||
|
Help: "US Cross Region Vault",
|
||||||
|
}, {
|
||||||
|
Value: "us-cold",
|
||||||
|
Help: "US Cross Region Cold",
|
||||||
|
}, {
|
||||||
|
Value: "us-flex",
|
||||||
|
Help: "US Cross Region Flex",
|
||||||
|
}, {
|
||||||
|
Value: "us-east-standard",
|
||||||
|
Help: "US East Region Standard",
|
||||||
|
}, {
|
||||||
|
Value: "us-east-vault",
|
||||||
|
Help: "US East Region Vault",
|
||||||
|
}, {
|
||||||
|
Value: "us-east-cold",
|
||||||
|
Help: "US East Region Cold",
|
||||||
|
}, {
|
||||||
|
Value: "us-east-flex",
|
||||||
|
Help: "US East Region Flex",
|
||||||
|
}, {
|
||||||
|
Value: "us-south-standard",
|
||||||
|
Help: "US Sout hRegion Standard",
|
||||||
|
}, {
|
||||||
|
Value: "us-south-vault",
|
||||||
|
Help: "US South Region Vault",
|
||||||
|
}, {
|
||||||
|
Value: "us-south-cold",
|
||||||
|
Help: "US South Region Cold",
|
||||||
|
}, {
|
||||||
|
Value: "us-south-flex",
|
||||||
|
Help: "US South Region Flex",
|
||||||
|
}, {
|
||||||
|
Value: "eu-standard",
|
||||||
|
Help: "EU Cross Region Standard",
|
||||||
|
}, {
|
||||||
|
Value: "eu-vault",
|
||||||
|
Help: "EU Cross Region Vault",
|
||||||
|
}, {
|
||||||
|
Value: "eu-cold",
|
||||||
|
Help: "EU Cross Region Cold",
|
||||||
|
}, {
|
||||||
|
Value: "eu-flex",
|
||||||
|
Help: "EU Cross Region Flex",
|
||||||
|
}, {
|
||||||
|
Value: "eu-gb-standard",
|
||||||
|
Help: "Great Britan Standard",
|
||||||
|
}, {
|
||||||
|
Value: "eu-gb-vault",
|
||||||
|
Help: "Great Britan Vault",
|
||||||
|
}, {
|
||||||
|
Value: "eu-gb-cold",
|
||||||
|
Help: "Great Britan Cold",
|
||||||
|
}, {
|
||||||
|
Value: "eu-gb-flex",
|
||||||
|
Help: "Great Britan Flex",
|
||||||
|
}, {
|
||||||
|
Value: "ap-standard",
|
||||||
|
Help: "APAC Standard",
|
||||||
|
}, {
|
||||||
|
Value: "ap-vault",
|
||||||
|
Help: "APAC Vault",
|
||||||
|
}, {
|
||||||
|
Value: "ap-cold",
|
||||||
|
Help: "APAC Cold",
|
||||||
|
}, {
|
||||||
|
Value: "ap-flex",
|
||||||
|
Help: "APAC Flex",
|
||||||
|
}, {
|
||||||
|
Value: "mel01-standard",
|
||||||
|
Help: "Melbourne Standard",
|
||||||
|
}, {
|
||||||
|
Value: "mel01-vault",
|
||||||
|
Help: "Melbourne Vault",
|
||||||
|
}, {
|
||||||
|
Value: "mel01-cold",
|
||||||
|
Help: "Melbourne Cold",
|
||||||
|
}, {
|
||||||
|
Value: "mel01-flex",
|
||||||
|
Help: "Melbourne Flex",
|
||||||
|
}, {
|
||||||
|
Value: "tor01-standard",
|
||||||
|
Help: "Toronto Standard",
|
||||||
|
}, {
|
||||||
|
Value: "tor01-vault",
|
||||||
|
Help: "Toronto Vault",
|
||||||
|
}, {
|
||||||
|
Value: "tor01-cold",
|
||||||
|
Help: "Toronto Cold",
|
||||||
|
}, {
|
||||||
|
Value: "tor01-flex",
|
||||||
|
Help: "Toronto Flex",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "location_constraint",
|
||||||
|
Help: "Location constraint - must be set to match the Region. Leave blank if not sure. Used when creating buckets only.",
|
||||||
|
Provider: "!AWS,IBMCOS",
|
||||||
|
}, {
|
||||||
|
Name: "acl",
|
||||||
|
Help: "Canned ACL used when creating buckets and/or storing objects in S3.\nFor more info visit https://docs.aws.amazon.com/AmazonS3/latest/dev/acl-overview.html#canned-acl",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "private",
|
||||||
|
Help: "Owner gets FULL_CONTROL. No one else has access rights (default).",
|
||||||
|
Provider: "!IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "public-read",
|
||||||
|
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ access.",
|
||||||
|
Provider: "!IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "public-read-write",
|
||||||
|
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ and WRITE access.\nGranting this on a bucket is generally not recommended.",
|
||||||
|
Provider: "!IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "authenticated-read",
|
||||||
|
Help: "Owner gets FULL_CONTROL. The AuthenticatedUsers group gets READ access.",
|
||||||
|
Provider: "!IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "bucket-owner-read",
|
||||||
|
Help: "Object owner gets FULL_CONTROL. Bucket owner gets READ access.\nIf you specify this canned ACL when creating a bucket, Amazon S3 ignores it.",
|
||||||
|
Provider: "!IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "bucket-owner-full-control",
|
||||||
|
Help: "Both the object owner and the bucket owner get FULL_CONTROL over the object.\nIf you specify this canned ACL when creating a bucket, Amazon S3 ignores it.",
|
||||||
|
Provider: "!IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "private",
|
||||||
|
Help: "Owner gets FULL_CONTROL. No one else has access rights (default). This acl is available on IBM Cloud (Infra), IBM Cloud (Storage), On-Premise COS",
|
||||||
|
Provider: "IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "public-read",
|
||||||
|
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ access. This acl is available on IBM Cloud (Infra), IBM Cloud (Storage), On-Premise IBM COS",
|
||||||
|
Provider: "IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "public-read-write",
|
||||||
|
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ and WRITE access. This acl is available on IBM Cloud (Infra), On-Premise IBM COS",
|
||||||
|
Provider: "IBMCOS",
|
||||||
|
}, {
|
||||||
|
Value: "authenticated-read",
|
||||||
|
Help: "Owner gets FULL_CONTROL. The AuthenticatedUsers group gets READ access. Not supported on Buckets. This acl is available on IBM Cloud (Infra) and On-Premise IBM COS",
|
||||||
|
Provider: "IBMCOS",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "server_side_encryption",
|
||||||
|
Help: "The server-side encryption algorithm used when storing this object in S3.",
|
||||||
|
Provider: "AWS",
|
||||||
|
Examples: []fs.OptionExample{{
|
||||||
|
Value: "",
|
||||||
|
Help: "None",
|
||||||
|
}, {
|
||||||
|
Value: "AES256",
|
||||||
|
Help: "AES256",
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
Name: "storage_class",
|
||||||
|
Help: "The storage class to use when storing objects in S3.",
|
||||||
|
Provider: "AWS",
|
||||||
|
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",
|
||||||
|
}, {
|
||||||
|
Value: "ONEZONE_IA",
|
||||||
|
Help: "One Zone Infrequent Access storage class",
|
||||||
|
}},
|
||||||
},
|
},
|
||||||
{
|
|
||||||
Name: "env_auth",
|
|
||||||
Help: "Get AWS credentials from runtime (environment variables or EC2/ECS meta data if no env vars). Only applies if access_key_id and secret_access_key is blank.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
Examples: []fs.OptionExample{
|
|
||||||
{
|
|
||||||
Value: "false",
|
|
||||||
Help: "Enter AWS credentials in the next step",
|
|
||||||
}, {
|
|
||||||
Value: "true",
|
|
||||||
Help: "Get AWS credentials from the environment (env vars or IAM)",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}, {
|
|
||||||
Name: "access_key_id",
|
|
||||||
Help: "AWS Access Key ID - leave blank for anonymous access or runtime credentials.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,IBMCOS,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Name: "secret_access_key",
|
|
||||||
Help: "AWS Secret Access Key (password) - leave blank for anonymous access or runtime credentials.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,IBMCOS,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Name: "region",
|
|
||||||
Help: "Region to connect to. Leave blank if you are using an S3 clone and you don't have a region.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
Examples: []fs.OptionExample{{
|
|
||||||
Value: "us-east-1",
|
|
||||||
Help: "The default endpoint - a good choice if you are unsure.\nUS Region, Northern Virginia or Pacific Northwest.\nLeave location constraint empty.",
|
|
||||||
}, {
|
|
||||||
Value: "us-east-2",
|
|
||||||
Help: "US East (Ohio) Region\nNeeds location constraint us-east-2.",
|
|
||||||
}, {
|
|
||||||
Value: "us-west-2",
|
|
||||||
Help: "US West (Oregon) Region\nNeeds location constraint us-west-2.",
|
|
||||||
}, {
|
|
||||||
Value: "us-west-1",
|
|
||||||
Help: "US West (Northern California) Region\nNeeds location constraint us-west-1.",
|
|
||||||
}, {
|
|
||||||
Value: "ca-central-1",
|
|
||||||
Help: "Canada (Central) Region\nNeeds location constraint ca-central-1.",
|
|
||||||
}, {
|
|
||||||
Value: "eu-west-1",
|
|
||||||
Help: "EU (Ireland) Region\nNeeds location constraint EU or eu-west-1.",
|
|
||||||
}, {
|
|
||||||
Value: "eu-west-2",
|
|
||||||
Help: "EU (London) Region\nNeeds location constraint eu-west-2.",
|
|
||||||
}, {
|
|
||||||
Value: "eu-central-1",
|
|
||||||
Help: "EU (Frankfurt) Region\nNeeds location constraint eu-central-1.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-southeast-1",
|
|
||||||
Help: "Asia Pacific (Singapore) Region\nNeeds location constraint ap-southeast-1.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-southeast-2",
|
|
||||||
Help: "Asia Pacific (Sydney) Region\nNeeds location constraint ap-southeast-2.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-northeast-1",
|
|
||||||
Help: "Asia Pacific (Tokyo) Region\nNeeds location constraint ap-northeast-1.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-northeast-2",
|
|
||||||
Help: "Asia Pacific (Seoul)\nNeeds location constraint ap-northeast-2.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-south-1",
|
|
||||||
Help: "Asia Pacific (Mumbai)\nNeeds location constraint ap-south-1.",
|
|
||||||
}, {
|
|
||||||
Value: "sa-east-1",
|
|
||||||
Help: "South America (Sao Paulo) Region\nNeeds location constraint sa-east-1.",
|
|
||||||
}, {
|
|
||||||
Value: "other-v2-signature",
|
|
||||||
Help: "Use this only if v4 signatures don't work, eg pre Jewel/v10 CEPH.\nSet this and make sure you set the endpoint.",
|
|
||||||
}},
|
|
||||||
}, {
|
|
||||||
Name: "endpoint",
|
|
||||||
Help: "Endpoint for S3 API.\nLeave blank if using AWS to use the default endpoint for the region.\nSpecify if using an S3 clone such as Ceph.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Name: "endpoint",
|
|
||||||
Help: "Endpoint for IBM COS S3 API.\nSpecify if using an IBM COS On Premise.",
|
|
||||||
Provider: "IBMCOS",
|
|
||||||
Examples: []fs.OptionExample{{
|
|
||||||
Value: "s3-api.us-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "US Cross Region Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.dal.us-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "US Cross Region Dallas Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.wdc-us-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "US Cross Region Washington DC Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.sjc-us-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "US Cross Region San Jose Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.us-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "US Cross Region Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.dal-us-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "US Cross Region Dallas Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.wdc-us-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "US Cross Region Washington DC Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3-api.sjc-us-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "US Cross Region San Jose Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.us-east.objectstorage.softlayer.net",
|
|
||||||
Help: "US Region East Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.us-east.objectstorage.service.networklayer.com",
|
|
||||||
Help: "US Region East Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.us-south.objectstorage.softlayer.net",
|
|
||||||
Help: "US Region South Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.us-south.objectstorage.service.networklayer.com",
|
|
||||||
Help: "US Region South Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.eu-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "EU Cross Region Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.fra-eu-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "EU Cross Region Frankfurt Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.mil-eu-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "EU Cross Region Milan Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.ams-eu-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "EU Cross Region Amsterdam Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.eu-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "EU Cross Region Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.fra-eu-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "EU Cross Region Frankfurt Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.mil-eu-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "EU Cross Region Milan Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.ams-eu-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "EU Cross Region Amsterdam Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.eu-gb.objectstorage.softlayer.net",
|
|
||||||
Help: "Great Britan Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.eu-gb.objectstorage.service.networklayer.com",
|
|
||||||
Help: "Great Britan Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.ap-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "APAC Cross Regional Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.tok-ap-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "APAC Cross Regional Tokyo Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.hkg-ap-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "APAC Cross Regional HongKong Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.seo-ap-geo.objectstorage.softlayer.net",
|
|
||||||
Help: "APAC Cross Regional Seoul Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.ap-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "APAC Cross Regional Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.tok-ap-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "APAC Cross Regional Tokyo Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.hkg-ap-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "APAC Cross Regional HongKong Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.seo-ap-geo.objectstorage.service.networklayer.com",
|
|
||||||
Help: "APAC Cross Regional Seoul Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.mel01.objectstorage.softlayer.net",
|
|
||||||
Help: "Melbourne Single Site Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.mel01.objectstorage.service.networklayer.com",
|
|
||||||
Help: "Melbourne Single Site Private Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.tor01.objectstorage.softlayer.net",
|
|
||||||
Help: "Toronto Single Site Endpoint",
|
|
||||||
}, {
|
|
||||||
Value: "s3.tor01.objectstorage.service.networklayer.com",
|
|
||||||
Help: "Toronto Single Site Private Endpoint",
|
|
||||||
}},
|
|
||||||
}, {
|
|
||||||
Name: "location_constraint",
|
|
||||||
Help: "Location constraint - must be set to match the Region. Used when creating buckets only.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio",
|
|
||||||
Examples: []fs.OptionExample{{
|
|
||||||
Value: "",
|
|
||||||
Help: "Empty for US Region, Northern Virginia or Pacific Northwest.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "us-east-2",
|
|
||||||
Help: "US East (Ohio) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "us-west-2",
|
|
||||||
Help: "US West (Oregon) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "us-west-1",
|
|
||||||
Help: "US West (Northern California) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "ca-central-1",
|
|
||||||
Help: "Canada (Central) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "eu-west-1",
|
|
||||||
Help: "EU (Ireland) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "eu-west-2",
|
|
||||||
Help: "EU (London) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "EU",
|
|
||||||
Help: "EU Region.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-southeast-1",
|
|
||||||
Help: "Asia Pacific (Singapore) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-southeast-2",
|
|
||||||
Help: "Asia Pacific (Sydney) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-northeast-1",
|
|
||||||
Help: "Asia Pacific (Tokyo) Region.",
|
|
||||||
}, {
|
|
||||||
Value: "ap-northeast-2",
|
|
||||||
Help: "Asia Pacific (Seoul)",
|
|
||||||
}, {
|
|
||||||
Value: "ap-south-1",
|
|
||||||
Help: "Asia Pacific (Mumbai)",
|
|
||||||
}, {
|
|
||||||
Value: "sa-east-1",
|
|
||||||
Help: "South America (Sao Paulo) Region.",
|
|
||||||
}},
|
|
||||||
}, {
|
|
||||||
Name: "location_constraint",
|
|
||||||
Help: "Location constraint - must match endpoint when using IBM Cloud Public. For on-prem COS, do not make a selection from this list, hit enter",
|
|
||||||
Provider: "IBMCOS",
|
|
||||||
Examples: []fs.OptionExample{{
|
|
||||||
Value: "us-standard",
|
|
||||||
Help: "US Cross Region Standard",
|
|
||||||
}, {
|
|
||||||
Value: "us-vault",
|
|
||||||
Help: "US Cross Region Vault",
|
|
||||||
}, {
|
|
||||||
Value: "us-cold",
|
|
||||||
Help: "US Cross Region Cold",
|
|
||||||
}, {
|
|
||||||
Value: "us-flex",
|
|
||||||
Help: "US Cross Region Flex",
|
|
||||||
}, {
|
|
||||||
Value: "us-east-standard",
|
|
||||||
Help: "US East Region Standard",
|
|
||||||
}, {
|
|
||||||
Value: "us-east-vault",
|
|
||||||
Help: "US East Region Vault",
|
|
||||||
}, {
|
|
||||||
Value: "us-east-cold",
|
|
||||||
Help: "US East Region Cold",
|
|
||||||
}, {
|
|
||||||
Value: "us-east-flex",
|
|
||||||
Help: "US East Region Flex",
|
|
||||||
}, {
|
|
||||||
Value: "us-south-standard",
|
|
||||||
Help: "US Sout hRegion Standard",
|
|
||||||
}, {
|
|
||||||
Value: "us-south-vault",
|
|
||||||
Help: "US South Region Vault",
|
|
||||||
}, {
|
|
||||||
Value: "us-south-cold",
|
|
||||||
Help: "US South Region Cold",
|
|
||||||
}, {
|
|
||||||
Value: "us-south-flex",
|
|
||||||
Help: "US South Region Flex",
|
|
||||||
}, {
|
|
||||||
Value: "eu-standard",
|
|
||||||
Help: "EU Cross Region Standard",
|
|
||||||
}, {
|
|
||||||
Value: "eu-vault",
|
|
||||||
Help: "EU Cross Region Vault",
|
|
||||||
}, {
|
|
||||||
Value: "eu-cold",
|
|
||||||
Help: "EU Cross Region Cold",
|
|
||||||
}, {
|
|
||||||
Value: "eu-flex",
|
|
||||||
Help: "EU Cross Region Flex",
|
|
||||||
}, {
|
|
||||||
Value: "eu-gb-standard",
|
|
||||||
Help: "Great Britan Standard",
|
|
||||||
}, {
|
|
||||||
Value: "eu-gb-vault",
|
|
||||||
Help: "Great Britan Vault",
|
|
||||||
}, {
|
|
||||||
Value: "eu-gb-cold",
|
|
||||||
Help: "Great Britan Cold",
|
|
||||||
}, {
|
|
||||||
Value: "eu-gb-flex",
|
|
||||||
Help: "Great Britan Flex",
|
|
||||||
}, {
|
|
||||||
Value: "ap-standard",
|
|
||||||
Help: "APAC Standard",
|
|
||||||
}, {
|
|
||||||
Value: "ap-vault",
|
|
||||||
Help: "APAC Vault",
|
|
||||||
}, {
|
|
||||||
Value: "ap-cold",
|
|
||||||
Help: "APAC Cold",
|
|
||||||
}, {
|
|
||||||
Value: "ap-flex",
|
|
||||||
Help: "APAC Flex",
|
|
||||||
}, {
|
|
||||||
Value: "mel01-standard",
|
|
||||||
Help: "Melbourne Standard",
|
|
||||||
}, {
|
|
||||||
Value: "mel01-vault",
|
|
||||||
Help: "Melbourne Vault",
|
|
||||||
}, {
|
|
||||||
Value: "mel01-cold",
|
|
||||||
Help: "Melbourne Cold",
|
|
||||||
}, {
|
|
||||||
Value: "mel01-flex",
|
|
||||||
Help: "Melbourne Flex",
|
|
||||||
}, {
|
|
||||||
Value: "tor01-standard",
|
|
||||||
Help: "Toronto Standard",
|
|
||||||
}, {
|
|
||||||
Value: "tor01-vault",
|
|
||||||
Help: "Toronto Vault",
|
|
||||||
}, {
|
|
||||||
Value: "tor01-cold",
|
|
||||||
Help: "Toronto Cold",
|
|
||||||
}, {
|
|
||||||
Value: "tor01-flex",
|
|
||||||
Help: "Toronto Flex",
|
|
||||||
}},
|
|
||||||
}, {
|
|
||||||
Name: "acl",
|
|
||||||
Help: "Canned ACL used when creating buckets and/or storing objects in S3.\nFor more info visit https://docs.aws.amazon.com/AmazonS3/latest/dev/acl-overview.html#canned-acl",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,IBMCOS,Minio,Other",
|
|
||||||
Examples: []fs.OptionExample{{
|
|
||||||
Value: "private",
|
|
||||||
Help: "Owner gets FULL_CONTROL. No one else has access rights (default).",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "public-read",
|
|
||||||
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ access.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "public-read-write",
|
|
||||||
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ and WRITE access.\nGranting this on a bucket is generally not recommended.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "authenticated-read",
|
|
||||||
Help: "Owner gets FULL_CONTROL. The AuthenticatedUsers group gets READ access.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "bucket-owner-read",
|
|
||||||
Help: "Object owner gets FULL_CONTROL. Bucket owner gets READ access.\nIf you specify this canned ACL when creating a bucket, Amazon S3 ignores it.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "bucket-owner-full-control",
|
|
||||||
Help: "Both the object owner and the bucket owner get FULL_CONTROL over the object.\nIf you specify this canned ACL when creating a bucket, Amazon S3 ignores it.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
}, {
|
|
||||||
Value: "private",
|
|
||||||
Help: "Owner gets FULL_CONTROL. No one else has access rights (default). This acl is available on IBM Cloud (Infra), IBM Cloud (Storage), On-Premise COS",
|
|
||||||
Provider: "IBMCOS",
|
|
||||||
}, {
|
|
||||||
Value: "public-read",
|
|
||||||
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ access. This acl is available on IBM Cloud (Infra), IBM Cloud (Storage), On-Premise IBM COS",
|
|
||||||
Provider: "IBMCOS",
|
|
||||||
}, {
|
|
||||||
Value: "public-read-write",
|
|
||||||
Help: "Owner gets FULL_CONTROL. The AllUsers group gets READ and WRITE access. This acl is available on IBM Cloud (Infra), On-Premise IBM COS",
|
|
||||||
Provider: "IBMCOS",
|
|
||||||
}, {
|
|
||||||
Value: "authenticated-read",
|
|
||||||
Help: "Owner gets FULL_CONTROL. The AuthenticatedUsers group gets READ access. Not supported on Buckets. This acl is available on IBM Cloud (Infra) and On-Premise IBM COS",
|
|
||||||
Provider: "IBMCOS",
|
|
||||||
}},
|
|
||||||
}, {
|
|
||||||
Name: "server_side_encryption",
|
|
||||||
Help: "The server-side encryption algorithm used when storing this object in S3.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
Examples: []fs.OptionExample{{
|
|
||||||
Value: "",
|
|
||||||
Help: "None",
|
|
||||||
}, {
|
|
||||||
Value: "AES256",
|
|
||||||
Help: "AES256",
|
|
||||||
}},
|
|
||||||
}, {
|
|
||||||
Name: "storage_class",
|
|
||||||
Help: "The storage class to use when storing objects in S3.",
|
|
||||||
Provider: "AWS,Ceph,Dreamhost,Minio,Other",
|
|
||||||
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",
|
|
||||||
}, {
|
|
||||||
Value: "ONEZONE_IA",
|
|
||||||
Help: "One Zone Infrequent Access storage class",
|
|
||||||
}},
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
flags.VarP(&s3ChunkSize, "s3-chunk-size", "", "Chunk size to use for uploading")
|
flags.VarP(&s3ChunkSize, "s3-chunk-size", "", "Chunk size to use for uploading")
|
||||||
|
|
|
@ -6,19 +6,42 @@ date: "2016-07-11"
|
||||||
|
|
||||||
<i class="fa fa-amazon"></i> Amazon S3 Storage Providers
|
<i class="fa fa-amazon"></i> Amazon S3 Storage Providers
|
||||||
--------------------------------------------------------
|
--------------------------------------------------------
|
||||||
* {{< provider name="AWS S3" home="https://aws.amazon.com/s3/" config="/s3/" >}}
|
|
||||||
|
The S3 backend can be used with a number of different providers:
|
||||||
|
|
||||||
|
* {{< provider name="AWS S3" home="https://aws.amazon.com/s3/" config="/s3/#amazon-s3" >}}
|
||||||
* {{< provider name="Ceph" home="http://ceph.com/" config="/s3/#ceph" >}}
|
* {{< provider name="Ceph" home="http://ceph.com/" config="/s3/#ceph" >}}
|
||||||
* {{< provider name="DigitalOcean Spaces" home="https://www.digitalocean.com/products/object-storage/" config="/s3/#digitalocean-spaces" >}}
|
* {{< provider name="DigitalOcean Spaces" home="https://www.digitalocean.com/products/object-storage/" config="/s3/#digitalocean-spaces" >}}
|
||||||
|
* {{< provider name="Dreamhost" home="https://www.dreamhost.com/cloud/storage/" config="/s3/#dreamhost" >}}
|
||||||
* {{< provider name="IBM COS S3" home="http://www.ibm.com/cloud/object-storage" config="/s3/#ibm-cos-s3" >}}
|
* {{< provider name="IBM COS S3" home="http://www.ibm.com/cloud/object-storage" config="/s3/#ibm-cos-s3" >}}
|
||||||
* {{< provider name="Minio" home="https://www.minio.io/" config="/s3/#minio" >}}
|
* {{< provider name="Minio" home="https://www.minio.io/" config="/s3/#minio" >}}
|
||||||
* {{< provider name="Wasabi" home="https://wasabi.com/" config="/s3/#wasabi" >}}
|
* {{< provider name="Wasabi" home="https://wasabi.com/" config="/s3/#wasabi" >}}
|
||||||
|
|
||||||
|
|
||||||
## AWS S3 {#amazon-s3}
|
|
||||||
|
|
||||||
Paths are specified as `remote:bucket` (or `remote:` for the `lsd`
|
Paths are specified as `remote:bucket` (or `remote:` for the `lsd`
|
||||||
command.) You may put subdirectories in too, eg `remote:bucket/path/to/dir`.
|
command.) You may put subdirectories in too, eg `remote:bucket/path/to/dir`.
|
||||||
|
|
||||||
|
Once you have made a remote (see the provider specific section above)
|
||||||
|
you can use it like this:
|
||||||
|
|
||||||
|
See all buckets
|
||||||
|
|
||||||
|
rclone lsd remote:
|
||||||
|
|
||||||
|
Make a new bucket
|
||||||
|
|
||||||
|
rclone mkdir remote:bucket
|
||||||
|
|
||||||
|
List the contents of a bucket
|
||||||
|
|
||||||
|
rclone ls remote:bucket
|
||||||
|
|
||||||
|
Sync `/home/local/directory` to the remote bucket, deleting any excess
|
||||||
|
files in the bucket.
|
||||||
|
|
||||||
|
rclone sync /home/local/directory remote:bucket
|
||||||
|
|
||||||
|
## AWS S3 {#amazon-s3}
|
||||||
|
|
||||||
Here is an example of making an s3 configuration. First run
|
Here is an example of making an s3 configuration. First run
|
||||||
|
|
||||||
rclone config
|
rclone config
|
||||||
|
@ -38,27 +61,33 @@ Choose a number from below, or type in your own value
|
||||||
\ "alias"
|
\ "alias"
|
||||||
2 / Amazon Drive
|
2 / Amazon Drive
|
||||||
\ "amazon cloud drive"
|
\ "amazon cloud drive"
|
||||||
3 / Amazon S3 Complaint Storage Providers (Dreamhost, Ceph, Minio, IBM COS)
|
3 / Amazon S3 Compliant Storage Providers (AWS, Ceph, Dreamhost, IBM COS, Minio)
|
||||||
\ "s3"
|
\ "s3"
|
||||||
4 / Backblaze B2
|
4 / Backblaze B2
|
||||||
\ "b2"
|
\ "b2"
|
||||||
[snip]
|
[snip]
|
||||||
23 / http Connection
|
23 / http Connection
|
||||||
\ "http"
|
\ "http"
|
||||||
Storage> 3
|
Storage> s3
|
||||||
Choose the S3 provider.
|
Choose your S3 provider.
|
||||||
Choose a number from below, or type in your own value
|
Choose a number from below, or type in your own value
|
||||||
1 / Choose this option to configure Storage to AWS S3
|
1 / Amazon Web Services (AWS) S3
|
||||||
\ "AWS"
|
\ "AWS"
|
||||||
2 / Choose this option to configure Storage to Ceph Systems
|
2 / Ceph Object Storage
|
||||||
\ "Ceph"
|
\ "Ceph"
|
||||||
3 / Choose this option to configure Storage to Dreamhost
|
3 / Digital Ocean Spaces
|
||||||
|
\ "DigitalOcean"
|
||||||
|
4 / Dreamhost DreamObjects
|
||||||
\ "Dreamhost"
|
\ "Dreamhost"
|
||||||
4 / Choose this option to the configure Storage to IBM COS S3
|
5 / IBM COS S3
|
||||||
\ "IBMCOS"
|
\ "IBMCOS"
|
||||||
5 / Choose this option to the configure Storage to Minio
|
6 / Minio Object Storage
|
||||||
\ "Minio"
|
\ "Minio"
|
||||||
Provider>1
|
7 / Wasabi Object Storage
|
||||||
|
\ "Wasabi"
|
||||||
|
8 / Any other S3 compatible provider
|
||||||
|
\ "Other"
|
||||||
|
provider> 1
|
||||||
Get AWS credentials from runtime (environment variables or EC2/ECS meta data if no env vars). Only applies if access_key_id and secret_access_key is blank.
|
Get AWS credentials from runtime (environment variables or EC2/ECS meta data if no env vars). Only applies if access_key_id and secret_access_key is blank.
|
||||||
Choose a number from below, or type in your own value
|
Choose a number from below, or type in your own value
|
||||||
1 / Enter AWS credentials in the next step
|
1 / Enter AWS credentials in the next step
|
||||||
|
@ -70,7 +99,7 @@ AWS Access Key ID - leave blank for anonymous access or runtime credentials.
|
||||||
access_key_id> XXX
|
access_key_id> XXX
|
||||||
AWS Secret Access Key (password) - leave blank for anonymous access or runtime credentials.
|
AWS Secret Access Key (password) - leave blank for anonymous access or runtime credentials.
|
||||||
secret_access_key> YYY
|
secret_access_key> YYY
|
||||||
Region to connect to. Leave blank if you are using an S3 clone and you don't have a region.
|
Region to connect to.
|
||||||
Choose a number from below, or type in your own value
|
Choose a number from below, or type in your own value
|
||||||
/ The default endpoint - a good choice if you are unsure.
|
/ The default endpoint - a good choice if you are unsure.
|
||||||
1 | US Region, Northern Virginia or Pacific Northwest.
|
1 | US Region, Northern Virginia or Pacific Northwest.
|
||||||
|
@ -115,14 +144,10 @@ Choose a number from below, or type in your own value
|
||||||
/ South America (Sao Paulo) Region
|
/ South America (Sao Paulo) Region
|
||||||
14 | Needs location constraint sa-east-1.
|
14 | Needs location constraint sa-east-1.
|
||||||
\ "sa-east-1"
|
\ "sa-east-1"
|
||||||
/ Use this only if v4 signatures don't work, eg pre Jewel/v10 CEPH.
|
|
||||||
15 | Set this and make sure you set the endpoint.
|
|
||||||
\ "other-v2-signature"
|
|
||||||
region> 1
|
region> 1
|
||||||
Endpoint for S3 API.
|
Endpoint for S3 API.
|
||||||
Leave blank if using AWS to use the default endpoint for the region.
|
Leave blank if using AWS to use the default endpoint for the region.
|
||||||
Specify if using an S3 clone such as Ceph.
|
endpoint>
|
||||||
endpoint>
|
|
||||||
Location constraint - must be set to match the Region. Used when creating buckets only.
|
Location constraint - must be set to match the Region. Used when creating buckets only.
|
||||||
Choose a number from below, or type in your own value
|
Choose a number from below, or type in your own value
|
||||||
1 / Empty for US Region, Northern Virginia or Pacific Northwest.
|
1 / Empty for US Region, Northern Virginia or Pacific Northwest.
|
||||||
|
@ -196,41 +221,24 @@ storage_class> 1
|
||||||
Remote config
|
Remote config
|
||||||
--------------------
|
--------------------
|
||||||
[remote]
|
[remote]
|
||||||
|
type = s3
|
||||||
|
provider = AWS
|
||||||
env_auth = false
|
env_auth = false
|
||||||
access_key_id = XXX
|
access_key_id = XXX
|
||||||
secret_access_key = YYY
|
secret_access_key = YYY
|
||||||
region = us-east-1
|
region = us-east-1
|
||||||
endpoint =
|
endpoint =
|
||||||
location_constraint =
|
location_constraint =
|
||||||
acl = private
|
acl = private
|
||||||
server_side_encryption =
|
server_side_encryption =
|
||||||
storage_class =
|
storage_class =
|
||||||
--------------------
|
--------------------
|
||||||
y) Yes this is OK
|
y) Yes this is OK
|
||||||
e) Edit this remote
|
e) Edit this remote
|
||||||
d) Delete this remote
|
d) Delete this remote
|
||||||
y/e/d> y
|
y/e/d>
|
||||||
```
|
```
|
||||||
|
|
||||||
This remote is called `remote` and can now be used like this
|
|
||||||
|
|
||||||
See all buckets
|
|
||||||
|
|
||||||
rclone lsd remote:
|
|
||||||
|
|
||||||
Make a new bucket
|
|
||||||
|
|
||||||
rclone mkdir remote:bucket
|
|
||||||
|
|
||||||
List the contents of a bucket
|
|
||||||
|
|
||||||
rclone ls remote:bucket
|
|
||||||
|
|
||||||
Sync `/home/local/directory` to the remote bucket, deleting any excess
|
|
||||||
files in the bucket.
|
|
||||||
|
|
||||||
rclone sync /home/local/directory remote:bucket
|
|
||||||
|
|
||||||
### --fast-list ###
|
### --fast-list ###
|
||||||
|
|
||||||
This remote supports `--fast-list` which allows you to use fewer
|
This remote supports `--fast-list` which allows you to use fewer
|
||||||
|
@ -270,6 +278,7 @@ you will get an error, `incorrect region, the bucket is not in 'XXX'
|
||||||
region`.
|
region`.
|
||||||
|
|
||||||
### Authentication ###
|
### Authentication ###
|
||||||
|
|
||||||
There are two ways to supply `rclone` with a set of AWS
|
There are two ways to supply `rclone` with a set of AWS
|
||||||
credentials. In order of precedence:
|
credentials. In order of precedence:
|
||||||
|
|
||||||
|
@ -282,8 +291,8 @@ credentials. In order of precedence:
|
||||||
- Access Key ID: `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY`
|
- Access Key ID: `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY`
|
||||||
- Secret Access Key: `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`
|
- Secret Access Key: `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`
|
||||||
- Session Token: `AWS_SESSION_TOKEN`
|
- Session Token: `AWS_SESSION_TOKEN`
|
||||||
- Running `rclone` in an ECS task with an IAM role
|
- Running `rclone` in an ECS task with an IAM role (AWS only)
|
||||||
- Running `rclone` on an EC2 instance with an IAM role
|
- Running `rclone` on an EC2 instance with an IAM role (AWS only)
|
||||||
|
|
||||||
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).
|
||||||
|
@ -387,44 +396,25 @@ Note that 2 chunks of this size are buffered in memory per transfer.
|
||||||
If you are transferring large files over high speed links and you have
|
If you are transferring large files over high speed links and you have
|
||||||
enough memory, then increasing this will speed up the transfers.
|
enough memory, then increasing this will speed up the transfers.
|
||||||
|
|
||||||
|
|
||||||
### 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
|
||||||
blank `access_key_id` and `secret_access_key`. Eg
|
blank `access_key_id` and `secret_access_key`. Your config should end
|
||||||
|
up looking like this:
|
||||||
|
|
||||||
```
|
```
|
||||||
No remotes found - make a new one
|
[anons3]
|
||||||
n) New remote
|
type = s3
|
||||||
q) Quit config
|
provider = AWS
|
||||||
n/q> n
|
env_auth = false
|
||||||
name> anons3
|
access_key_id =
|
||||||
What type of source is it?
|
secret_access_key =
|
||||||
Choose a number from below
|
region = us-east-1
|
||||||
1) amazon cloud drive
|
endpoint =
|
||||||
2) b2
|
location_constraint =
|
||||||
3) drive
|
acl = private
|
||||||
4) dropbox
|
server_side_encryption =
|
||||||
5) google cloud storage
|
storage_class =
|
||||||
6) swift
|
|
||||||
7) hubic
|
|
||||||
8) local
|
|
||||||
9) onedrive
|
|
||||||
10) s3
|
|
||||||
11) yandex
|
|
||||||
type> 10
|
|
||||||
Get AWS credentials from runtime (environment variables or EC2/ECS meta data if no env vars). Only applies if access_key_id and secret_access_key is blank.
|
|
||||||
Choose a number from below, or type in your own value
|
|
||||||
* Enter AWS credentials in the next step
|
|
||||||
1) false
|
|
||||||
* Get AWS credentials from the environment (env vars or IAM)
|
|
||||||
2) true
|
|
||||||
env_auth> 1
|
|
||||||
AWS Access Key ID - leave blank for anonymous access or runtime credentials.
|
|
||||||
access_key_id>
|
|
||||||
AWS Secret Access Key (password) - leave blank for anonymous access or runtime credentials.
|
|
||||||
secret_access_key>
|
|
||||||
...
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Then use it as normal with the name of the public bucket, eg
|
Then use it as normal with the name of the public bucket, eg
|
||||||
|
@ -447,6 +437,7 @@ your config:
|
||||||
```
|
```
|
||||||
[ceph]
|
[ceph]
|
||||||
type = s3
|
type = s3
|
||||||
|
provider = Ceph
|
||||||
env_auth = false
|
env_auth = false
|
||||||
access_key_id = XXX
|
access_key_id = XXX
|
||||||
secret_access_key = YYY
|
secret_access_key = YYY
|
||||||
|
@ -494,6 +485,8 @@ your config:
|
||||||
|
|
||||||
```
|
```
|
||||||
[dreamobjects]
|
[dreamobjects]
|
||||||
|
type = s3
|
||||||
|
provider = DreamHost
|
||||||
env_auth = false
|
env_auth = false
|
||||||
access_key_id = your_access_key
|
access_key_id = your_access_key
|
||||||
secret_access_key = your_secret_key
|
secret_access_key = your_secret_key
|
||||||
|
@ -505,7 +498,6 @@ server_side_encryption =
|
||||||
storage_class =
|
storage_class =
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### DigitalOcean Spaces ###
|
### DigitalOcean Spaces ###
|
||||||
|
|
||||||
[Spaces](https://www.digitalocean.com/products/object-storage/) is an [S3-interoperable](https://developers.digitalocean.com/documentation/spaces/) object storage service from cloud provider DigitalOcean.
|
[Spaces](https://www.digitalocean.com/products/object-storage/) is an [S3-interoperable](https://developers.digitalocean.com/documentation/spaces/) object storage service from cloud provider DigitalOcean.
|
||||||
|
@ -533,6 +525,7 @@ The resulting configuration file should look like:
|
||||||
```
|
```
|
||||||
[spaces]
|
[spaces]
|
||||||
type = s3
|
type = s3
|
||||||
|
provider = DigitalOcean
|
||||||
env_auth = false
|
env_auth = false
|
||||||
access_key_id = YOUR_ACCESS_KEY
|
access_key_id = YOUR_ACCESS_KEY
|
||||||
secret_access_key = YOUR_SECRET_KEY
|
secret_access_key = YOUR_SECRET_KEY
|
||||||
|
@ -552,6 +545,7 @@ rclone copy /path/to/files spaces:my-new-space
|
||||||
```
|
```
|
||||||
|
|
||||||
### IBM COS (S3) ###
|
### IBM COS (S3) ###
|
||||||
|
|
||||||
Information stored with IBM Cloud Object Storage is encrypted and dispersed across multiple geographic locations, and accessed through an implementation of the S3 API. This service makes use of the distributed storage technologies provided by IBM’s Cloud Object Storage System (formerly Cleversafe). For more information visit: (http://www.ibm.com/cloud/object-storage)
|
Information stored with IBM Cloud Object Storage is encrypted and dispersed across multiple geographic locations, and accessed through an implementation of the S3 API. This service makes use of the distributed storage technologies provided by IBM’s Cloud Object Storage System (formerly Cleversafe). For more information visit: (http://www.ibm.com/cloud/object-storage)
|
||||||
|
|
||||||
To configure access to IBM COS S3, follow the steps below:
|
To configure access to IBM COS S3, follow the steps below:
|
||||||
|
@ -772,6 +766,8 @@ Which makes the config file look like this
|
||||||
|
|
||||||
```
|
```
|
||||||
[minio]
|
[minio]
|
||||||
|
type = s3
|
||||||
|
provider = Minio
|
||||||
env_auth = false
|
env_auth = false
|
||||||
access_key_id = USWUXHGYZQYFYFFIT3RE
|
access_key_id = USWUXHGYZQYFYFFIT3RE
|
||||||
secret_access_key = MOJRH0mkL1IPauahWITSVvyDrQbEEIwljvmxdq03
|
secret_access_key = MOJRH0mkL1IPauahWITSVvyDrQbEEIwljvmxdq03
|
||||||
|
@ -888,10 +884,12 @@ This will leave the config file looking like this.
|
||||||
|
|
||||||
```
|
```
|
||||||
[wasabi]
|
[wasabi]
|
||||||
|
type = s3
|
||||||
|
provider = Wasabi
|
||||||
env_auth = false
|
env_auth = false
|
||||||
access_key_id = YOURACCESSKEY
|
access_key_id = YOURACCESSKEY
|
||||||
secret_access_key = YOURSECRETACCESSKEY
|
secret_access_key = YOURSECRETACCESSKEY
|
||||||
region = us-east-1
|
region =
|
||||||
endpoint = s3.wasabisys.com
|
endpoint = s3.wasabisys.com
|
||||||
location_constraint =
|
location_constraint =
|
||||||
acl =
|
acl =
|
||||||
|
|
Loading…
Reference in a new issue