mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-24 22:38:23 +00:00
Merge pull request #912 from ggtakec/master
Automatic region change made possible other than us-east-1(default)
This commit is contained in:
commit
beadf95975
14
src/s3fs.cpp
14
src/s3fs.cpp
@ -134,7 +134,6 @@ static bool is_ibm_iam_auth = false;
|
|||||||
static bool is_use_xattr = false;
|
static bool is_use_xattr = false;
|
||||||
static bool create_bucket = false;
|
static bool create_bucket = false;
|
||||||
static int64_t singlepart_copy_limit = FIVE_GB;
|
static int64_t singlepart_copy_limit = FIVE_GB;
|
||||||
static bool is_specified_endpoint = false;
|
|
||||||
static int s3fs_init_deferred_exit_status = 0;
|
static int s3fs_init_deferred_exit_status = 0;
|
||||||
static bool support_compat_dir = true;// default supports compatibility directory type
|
static bool support_compat_dir = true;// default supports compatibility directory type
|
||||||
static int max_keys_list_object = 1000;// default is 1000
|
static int max_keys_list_object = 1000;// default is 1000
|
||||||
@ -3714,7 +3713,7 @@ static int s3fs_utility_mode(void)
|
|||||||
//
|
//
|
||||||
// So this is cheep codes but s3fs should get correct region automatically.
|
// So this is cheep codes but s3fs should get correct region automatically.
|
||||||
//
|
//
|
||||||
static bool check_region_error(const char* pbody, string& expectregion)
|
static bool check_region_error(const char* pbody, const string& currentep, string& expectregion)
|
||||||
{
|
{
|
||||||
if(!pbody){
|
if(!pbody){
|
||||||
return false;
|
return false;
|
||||||
@ -3724,6 +3723,10 @@ static bool check_region_error(const char* pbody, string& expectregion)
|
|||||||
if(NULL == (region = strcasestr(pbody, "<Message>The authorization header is malformed; the region "))){
|
if(NULL == (region = strcasestr(pbody, "<Message>The authorization header is malformed; the region "))){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
// check current endpoint region in body.
|
||||||
|
if(NULL == (region = strcasestr(region, currentep.c_str()))){
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if(NULL == (region = strcasestr(region, "expecting \'"))){
|
if(NULL == (region = strcasestr(region, "expecting \'"))){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -3757,12 +3760,12 @@ static int s3fs_check_service(void)
|
|||||||
long responseCode = s3fscurl.GetLastResponseCode();
|
long responseCode = s3fscurl.GetLastResponseCode();
|
||||||
|
|
||||||
// check wrong endpoint, and automatically switch endpoint
|
// check wrong endpoint, and automatically switch endpoint
|
||||||
if(responseCode == 400 && !is_specified_endpoint){
|
if(300 <= responseCode && responseCode < 500){
|
||||||
// check region error
|
// check region error
|
||||||
BodyData* body = s3fscurl.GetBodyData();
|
BodyData* body = s3fscurl.GetBodyData();
|
||||||
string expectregion;
|
string expectregion;
|
||||||
if(check_region_error(body->str(), expectregion)){
|
if(check_region_error(body->str(), endpoint, expectregion)){
|
||||||
// not specified endpoint, so try to connect to expected region.
|
// current endpoint is wrong, so try to connect to expected region.
|
||||||
S3FS_PRN_CRIT("Could not connect wrong region %s, so retry to connect region %s.", endpoint.c_str(), expectregion.c_str());
|
S3FS_PRN_CRIT("Could not connect wrong region %s, so retry to connect region %s.", endpoint.c_str(), expectregion.c_str());
|
||||||
endpoint = expectregion;
|
endpoint = expectregion;
|
||||||
if(S3fsCurl::IsSignatureV4()){
|
if(S3fsCurl::IsSignatureV4()){
|
||||||
@ -4841,7 +4844,6 @@ static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_ar
|
|||||||
}
|
}
|
||||||
if(0 == STR2NCMP(arg, "endpoint=")){
|
if(0 == STR2NCMP(arg, "endpoint=")){
|
||||||
endpoint = strchr(arg, '=') + sizeof(char);
|
endpoint = strchr(arg, '=') + sizeof(char);
|
||||||
is_specified_endpoint = true;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(0 == strcmp(arg, "use_path_request_style")){
|
if(0 == strcmp(arg, "use_path_request_style")){
|
||||||
|
Loading…
x
Reference in New Issue
Block a user