mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-23 13:58:24 +00:00
Merge pull request #271 from andrewgaul/storage-class
Add support for standard_ia storage class
This commit is contained in:
commit
6a9082f126
26
src/curl.cpp
26
src/curl.cpp
@ -252,7 +252,7 @@ time_t S3fsCurl::readwrite_timeout = 60; // default
|
|||||||
int S3fsCurl::retries = 3; // default
|
int S3fsCurl::retries = 3; // default
|
||||||
bool S3fsCurl::is_public_bucket = false;
|
bool S3fsCurl::is_public_bucket = false;
|
||||||
string S3fsCurl::default_acl = "private";
|
string S3fsCurl::default_acl = "private";
|
||||||
bool S3fsCurl::is_use_rrs = false;
|
storage_class_t S3fsCurl::storage_class = STANDARD;
|
||||||
sseckeylist_t S3fsCurl::sseckeys;
|
sseckeylist_t S3fsCurl::sseckeys;
|
||||||
bool S3fsCurl::is_use_sse = false;
|
bool S3fsCurl::is_use_sse = false;
|
||||||
bool S3fsCurl::is_content_md5 = false;
|
bool S3fsCurl::is_content_md5 = false;
|
||||||
@ -790,10 +790,10 @@ string S3fsCurl::SetDefaultAcl(const char* acl)
|
|||||||
return old;
|
return old;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool S3fsCurl::SetUseRrs(bool flag)
|
storage_class_t S3fsCurl::SetStorageClass(storage_class_t storage_class)
|
||||||
{
|
{
|
||||||
bool old = S3fsCurl::is_use_rrs;
|
storage_class_t old = S3fsCurl::storage_class;
|
||||||
S3fsCurl::is_use_rrs = flag;
|
S3fsCurl::storage_class = storage_class;
|
||||||
return old;
|
return old;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2263,10 +2263,12 @@ int S3fsCurl::PutHeadRequest(const char* tpath, headers_t& meta, bool is_copy)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// "x-amz-acl", rrs, sse
|
// "x-amz-acl", storage class, sse
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-acl", S3fsCurl::default_acl.c_str());
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-acl", S3fsCurl::default_acl.c_str());
|
||||||
if(S3fsCurl::is_use_rrs){
|
if(REDUCED_REDUNDANCY == GetStorageClass()){
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "REDUCED_REDUNDANCY");
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "REDUCED_REDUNDANCY");
|
||||||
|
} else if(STANDARD_IA == GetStorageClass()){
|
||||||
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "STANDARD_IA");
|
||||||
}
|
}
|
||||||
if(S3fsCurl::is_use_sse){
|
if(S3fsCurl::is_use_sse){
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-server-side-encryption", "AES256");
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-server-side-encryption", "AES256");
|
||||||
@ -2381,10 +2383,12 @@ int S3fsCurl::PutRequest(const char* tpath, headers_t& meta, int fd)
|
|||||||
// skip this header, because this header is specified after logic.
|
// skip this header, because this header is specified after logic.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// "x-amz-acl", rrs, sse
|
// "x-amz-acl", storage class, sse
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-acl", S3fsCurl::default_acl.c_str());
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-acl", S3fsCurl::default_acl.c_str());
|
||||||
if(S3fsCurl::is_use_rrs){
|
if(REDUCED_REDUNDANCY == GetStorageClass()){
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "REDUCED_REDUNDANCY");
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "REDUCED_REDUNDANCY");
|
||||||
|
} else if(STANDARD_IA == GetStorageClass()){
|
||||||
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "STANDARD_IA");
|
||||||
}
|
}
|
||||||
if(S3fsCurl::is_use_sse){
|
if(S3fsCurl::is_use_sse){
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-server-side-encryption", "AES256");
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-server-side-encryption", "AES256");
|
||||||
@ -2684,10 +2688,12 @@ int S3fsCurl::PreMultipartPostRequest(const char* tpath, headers_t& meta, string
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// "x-amz-acl", rrs, sse
|
// "x-amz-acl", storage class, sse
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-acl", S3fsCurl::default_acl.c_str());
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-acl", S3fsCurl::default_acl.c_str());
|
||||||
if(S3fsCurl::is_use_rrs){
|
if(REDUCED_REDUNDANCY == GetStorageClass()){
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "REDUCED_REDUNDANCY");
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "REDUCED_REDUNDANCY");
|
||||||
|
} else if(STANDARD_IA == GetStorageClass()){
|
||||||
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-storage-class", "STANDARD_IA");
|
||||||
}
|
}
|
||||||
if(S3fsCurl::is_use_sse){
|
if(S3fsCurl::is_use_sse){
|
||||||
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-server-side-encryption", "AES256");
|
requestHeaders = curl_slist_sort_insert(requestHeaders, "x-amz-server-side-encryption", "AES256");
|
||||||
|
12
src/curl.h
12
src/curl.h
@ -122,6 +122,12 @@ typedef std::map<std::string, std::string> iamcredmap_t;
|
|||||||
typedef std::map<std::string, std::string> sseckeymap_t;
|
typedef std::map<std::string, std::string> sseckeymap_t;
|
||||||
typedef std::list<sseckeymap_t> sseckeylist_t;
|
typedef std::list<sseckeymap_t> sseckeylist_t;
|
||||||
|
|
||||||
|
enum storage_class_t {
|
||||||
|
STANDARD,
|
||||||
|
STANDARD_IA,
|
||||||
|
REDUCED_REDUNDANCY,
|
||||||
|
};
|
||||||
|
|
||||||
// share
|
// share
|
||||||
#define SHARE_MUTEX_DNS 0
|
#define SHARE_MUTEX_DNS 0
|
||||||
#define SHARE_MUTEX_SSL_SESSION 1
|
#define SHARE_MUTEX_SSL_SESSION 1
|
||||||
@ -165,7 +171,7 @@ class S3fsCurl
|
|||||||
static int retries;
|
static int retries;
|
||||||
static bool is_public_bucket;
|
static bool is_public_bucket;
|
||||||
static std::string default_acl; // TODO: to enum
|
static std::string default_acl; // TODO: to enum
|
||||||
static bool is_use_rrs;
|
static storage_class_t storage_class;
|
||||||
static sseckeylist_t sseckeys;
|
static sseckeylist_t sseckeys;
|
||||||
static bool is_use_sse;
|
static bool is_use_sse;
|
||||||
static bool is_content_md5;
|
static bool is_content_md5;
|
||||||
@ -278,8 +284,8 @@ class S3fsCurl
|
|||||||
static bool SetPublicBucket(bool flag);
|
static bool SetPublicBucket(bool flag);
|
||||||
static bool IsPublicBucket(void) { return S3fsCurl::is_public_bucket; }
|
static bool IsPublicBucket(void) { return S3fsCurl::is_public_bucket; }
|
||||||
static std::string SetDefaultAcl(const char* acl);
|
static std::string SetDefaultAcl(const char* acl);
|
||||||
static bool SetUseRrs(bool flag);
|
static storage_class_t SetStorageClass(storage_class_t storage_class);
|
||||||
static bool GetUseRrs(void) { return S3fsCurl::is_use_rrs; }
|
static storage_class_t GetStorageClass() { return S3fsCurl::storage_class; }
|
||||||
static bool SetSseKeys(const char* filepath);
|
static bool SetSseKeys(const char* filepath);
|
||||||
static bool LoadEnvSseKeys(void);
|
static bool LoadEnvSseKeys(void);
|
||||||
static bool GetSseKey(std::string& md5, std::string& ssekey);
|
static bool GetSseKey(std::string& md5, std::string& ssekey);
|
||||||
|
31
src/s3fs.cpp
31
src/s3fs.cpp
@ -4218,6 +4218,7 @@ static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_ar
|
|||||||
nomultipart = true;
|
nomultipart = true;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
// old format for storage_class
|
||||||
if(0 == strcmp(arg, "use_rrs") || 0 == STR2NCMP(arg, "use_rrs=")){
|
if(0 == strcmp(arg, "use_rrs") || 0 == STR2NCMP(arg, "use_rrs=")){
|
||||||
off_t rrs = 1;
|
off_t rrs = 1;
|
||||||
// for an old format.
|
// for an old format.
|
||||||
@ -4225,23 +4226,41 @@ static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_ar
|
|||||||
rrs = s3fs_strtoofft(strchr(arg, '=') + sizeof(char));
|
rrs = s3fs_strtoofft(strchr(arg, '=') + sizeof(char));
|
||||||
}
|
}
|
||||||
if(0 == rrs){
|
if(0 == rrs){
|
||||||
S3fsCurl::SetUseRrs(false);
|
S3fsCurl::SetStorageClass(STANDARD);
|
||||||
}else if(1 == rrs){
|
}else if(1 == rrs){
|
||||||
if(S3fsCurl::GetUseSse()){
|
if(S3fsCurl::GetUseSse()){
|
||||||
fprintf(stderr, "%s: use_rrs option could not be specified with use_sse.\n", program_name.c_str());
|
fprintf(stderr, "%s: use_rrs option could not be specified with use_sse.\n", program_name.c_str());
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
S3fsCurl::SetUseRrs(true);
|
S3fsCurl::SetStorageClass(REDUCED_REDUNDANCY);
|
||||||
}else{
|
}else{
|
||||||
fprintf(stderr, "%s: poorly formed argument to option: use_rrs\n", program_name.c_str());
|
fprintf(stderr, "%s: poorly formed argument to option: use_rrs\n", program_name.c_str());
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
if(0 == STR2NCMP(arg, "storage_class=")){
|
||||||
|
const char *storage_class = strchr(arg, '=') + sizeof(char);
|
||||||
|
if(0 == strcmp(storage_class, "standard")){
|
||||||
|
S3fsCurl::SetStorageClass(STANDARD);
|
||||||
|
}else if(0 == strcmp(storage_class, "standard_ia")){
|
||||||
|
S3fsCurl::SetStorageClass(STANDARD_IA);
|
||||||
|
}else if(0 == strcmp(storage_class, "reduced_redundancy")){
|
||||||
|
if(S3fsCurl::GetUseSse()){
|
||||||
|
fprintf(stderr, "%s: storage class reduced_redundancy option could not be specified with use_sse.\n", program_name.c_str());
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
S3fsCurl::SetStorageClass(REDUCED_REDUNDANCY);
|
||||||
|
}else{
|
||||||
|
fprintf(stderr, "%s: unknown value for storage_class: %s\n", program_name.c_str(), storage_class);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
if(0 == strcmp(arg, "use_sse") || 0 == STR2NCMP(arg, "use_sse=")){
|
if(0 == strcmp(arg, "use_sse") || 0 == STR2NCMP(arg, "use_sse=")){
|
||||||
if(0 == STR2NCMP(arg, "use_sse=")){
|
if(0 == STR2NCMP(arg, "use_sse=")){
|
||||||
if(S3fsCurl::GetUseRrs()){
|
if(REDUCED_REDUNDANCY == S3fsCurl::GetStorageClass()){
|
||||||
fprintf(stderr, "%s: use_sse option could not be specified with use_rrs.\n", program_name.c_str());
|
fprintf(stderr, "%s: use_sse option could not be specified with storage class reduced_redundancy.\n", program_name.c_str());
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
const char* ssecfile = &arg[strlen("use_sse=")];
|
const char* ssecfile = &arg[strlen("use_sse=")];
|
||||||
@ -4268,8 +4287,8 @@ static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_ar
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
if(S3fsCurl::GetUseRrs()){
|
if(REDUCED_REDUNDANCY == S3fsCurl::GetStorageClass()){
|
||||||
fprintf(stderr, "%s: use_sse option could not be specified with use_rrs.\n", program_name.c_str());
|
fprintf(stderr, "%s: use_sse option could not be specified with storage class reduced_redundancy.\n", program_name.c_str());
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if(S3fsCurl::IsSseCustomMode()){
|
if(S3fsCurl::IsSseCustomMode()){
|
||||||
|
@ -894,8 +894,9 @@ void show_help (void)
|
|||||||
" del_cache (delete local file cache)\n"
|
" del_cache (delete local file cache)\n"
|
||||||
" - delete local file cache when s3fs starts and exits.\n"
|
" - delete local file cache when s3fs starts and exits.\n"
|
||||||
"\n"
|
"\n"
|
||||||
" use_rrs (default is disable)\n"
|
" storage_class (default=\"standard\")\n"
|
||||||
" - this option makes Amazon's Reduced Redundancy Storage enable.\n"
|
" - store object with specified storage class. Possible values:\n"
|
||||||
|
" standard, standard_ia, and reduced_redundancy.\n"
|
||||||
"\n"
|
"\n"
|
||||||
" use_sse (default is disable)\n"
|
" use_sse (default is disable)\n"
|
||||||
" - use Amazon's Server-Site Encryption or Server-Side Encryption\n"
|
" - use Amazon's Server-Site Encryption or Server-Side Encryption\n"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user