Default uid/gid/mode when object lacks permissions

This addresses a common use case when interacting with objects from
both s3fs and other S3 tools.  Fixes #890.
This commit is contained in:
Andrew Gaul 2019-01-13 19:41:39 -08:00
parent 4ed0e5f35a
commit e2d5641d99

View File

@ -792,11 +792,13 @@ mode_t get_mode(headers_t& meta, const char* path, bool checkdir, bool forcedir)
if(meta.end() != (iter = meta.find("x-amz-meta-mode"))){ if(meta.end() != (iter = meta.find("x-amz-meta-mode"))){
mode = get_mode((*iter).second.c_str()); mode = get_mode((*iter).second.c_str());
}else{ }else if(meta.end() != (iter = meta.find("x-amz-meta-permissions"))){ // for s3sync
if(meta.end() != (iter = meta.find("x-amz-meta-permissions"))){ // for s3sync
mode = get_mode((*iter).second.c_str()); mode = get_mode((*iter).second.c_str());
isS3sync = true; isS3sync = true;
} }else{
// If another tool creates an object without permissions, default to owner
// read-write and group readable.
mode = path[strlen(path) - 1] == '/' ? 0750 : 0640;
} }
// Checking the bitmask, if the last 3 bits are all zero then process as a regular // Checking the bitmask, if the last 3 bits are all zero then process as a regular
// file type (S_IFDIR or S_IFREG), otherwise return mode unmodified so that S_IFIFO, // file type (S_IFDIR or S_IFREG), otherwise return mode unmodified so that S_IFIFO,
@ -866,12 +868,13 @@ uid_t get_uid(const char *s)
uid_t get_uid(headers_t& meta) uid_t get_uid(headers_t& meta)
{ {
headers_t::const_iterator iter; headers_t::const_iterator iter;
if(meta.end() == (iter = meta.find("x-amz-meta-uid"))){ if(meta.end() != (iter = meta.find("x-amz-meta-uid"))){
if(meta.end() == (iter = meta.find("x-amz-meta-owner"))){ // for s3sync
return 0;
}
}
return get_uid((*iter).second.c_str()); return get_uid((*iter).second.c_str());
}else if(meta.end() != (iter = meta.find("x-amz-meta-owner"))){ // for s3sync
return get_uid((*iter).second.c_str());
}else{
return geteuid();
}
} }
gid_t get_gid(const char *s) gid_t get_gid(const char *s)
@ -882,12 +885,13 @@ gid_t get_gid(const char *s)
gid_t get_gid(headers_t& meta) gid_t get_gid(headers_t& meta)
{ {
headers_t::const_iterator iter; headers_t::const_iterator iter;
if(meta.end() == (iter = meta.find("x-amz-meta-gid"))){ if(meta.end() != (iter = meta.find("x-amz-meta-gid"))){
if(meta.end() == (iter = meta.find("x-amz-meta-group"))){ // for s3sync
return 0;
}
}
return get_gid((*iter).second.c_str()); return get_gid((*iter).second.c_str());
}else if(meta.end() != (iter = meta.find("x-amz-meta-group"))){ // for s3sync
return get_gid((*iter).second.c_str());
}else{
return getegid();
}
} }
blkcnt_t get_blocks(off_t size) blkcnt_t get_blocks(off_t size)