Remove `create_parents_dir` parameter when creating directories

Can't create parents on Windows using pywin32.
Removed it completely so that behavior is consistent across OSes.
This commit is contained in:
shreyamalviya 2021-06-10 15:19:40 +05:30
parent 1fa2ffe8f7
commit 74111f80e9
4 changed files with 14 additions and 29 deletions

View File

@ -16,21 +16,18 @@ if is_windows_os():
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
def create_secure_directory(path: str, create_parent_dirs: bool): def create_secure_directory(path: str):
if not os.path.isdir(path): if not os.path.isdir(path):
if is_windows_os(): if is_windows_os():
_create_secure_directory_windows(path) _create_secure_directory_windows(path)
else: else:
_create_secure_directory_linux(path, create_parent_dirs) _create_secure_directory_linux(path)
def _create_secure_directory_linux(path: str, create_parent_dirs: bool): def _create_secure_directory_linux(path: str):
try: try:
if create_parent_dirs:
# Don't split directory creation and permission setting # Don't split directory creation and permission setting
# because it will temporarily create an accessible directory which anyone can use. # because it will temporarily create an accessible directory which anyone can use.
os.makedirs(path, mode=0o700)
else:
os.mkdir(path, mode=0o700) os.mkdir(path, mode=0o700)
except Exception as ex: except Exception as ex:
LOG.error( LOG.error(

View File

@ -18,7 +18,7 @@ def setup_data_dir(island_args: IslandCmdArgs) -> Tuple[IslandConfigOptions, str
def _setup_config_by_cmd_arg(server_config_path) -> Tuple[IslandConfigOptions, str]: def _setup_config_by_cmd_arg(server_config_path) -> Tuple[IslandConfigOptions, str]:
server_config_path = file_utils.expand_path(server_config_path) server_config_path = file_utils.expand_path(server_config_path)
config = server_config_handler.load_server_config_from_file(server_config_path) config = server_config_handler.load_server_config_from_file(server_config_path)
create_secure_directory(config.data_dir, create_parent_dirs=True) create_secure_directory(config.data_dir)
return config, server_config_path return config, server_config_path
@ -26,7 +26,7 @@ def _setup_default_config() -> Tuple[IslandConfigOptions, str]:
default_config = server_config_handler.load_server_config_from_file(DEFAULT_SERVER_CONFIG_PATH) default_config = server_config_handler.load_server_config_from_file(DEFAULT_SERVER_CONFIG_PATH)
default_data_dir = default_config.data_dir default_data_dir = default_config.data_dir
create_secure_directory(default_data_dir, create_parent_dirs=False) create_secure_directory(default_data_dir)
server_config_path = server_config_handler.create_default_server_config_file(default_data_dir) server_config_path = server_config_handler.create_default_server_config_file(default_data_dir)
config = server_config_handler.load_server_config_from_file(server_config_path) config = server_config_handler.load_server_config_from_file(server_config_path)

View File

@ -35,7 +35,7 @@ def _create_db_dir(db_dir_parent_path) -> str:
db_dir = os.path.join(db_dir_parent_path, DB_DIR_NAME) db_dir = os.path.join(db_dir_parent_path, DB_DIR_NAME)
logger.info(f"Database content directory: {db_dir}.") logger.info(f"Database content directory: {db_dir}.")
create_secure_directory(db_dir, create_parent_dirs=False) create_secure_directory(db_dir)
return db_dir return db_dir

View File

@ -20,38 +20,26 @@ def test_path(tmpdir):
return path return path
def test_create_secure_directory__parent_dirs(test_path_nested):
create_secure_directory(test_path_nested, create_parent_dirs=True)
assert os.path.isdir(test_path_nested)
def test_create_secure_directory__already_created(test_path): def test_create_secure_directory__already_created(test_path):
os.mkdir(test_path) os.mkdir(test_path)
assert os.path.isdir(test_path) assert os.path.isdir(test_path)
create_secure_directory(test_path, create_parent_dirs=False) create_secure_directory(test_path)
def test_create_secure_directory__no_parent_dir(test_path_nested): def test_create_secure_directory__no_parent_dir(test_path_nested):
with pytest.raises(Exception): with pytest.raises(Exception):
create_secure_directory(test_path_nested, create_parent_dirs=False) create_secure_directory(test_path_nested)
@pytest.mark.skipif(is_windows_os(), reason="Tests Posix (not Windows) permissions.")
def test_create_secure_directory__perm_linux(test_path_nested):
create_secure_directory(test_path_nested, create_parent_dirs=True)
st = os.stat(test_path_nested)
return bool(st.st_mode & stat.S_IRWXU)
@pytest.mark.skipif(not is_windows_os(), reason="Tests Windows (not Posix) permissions.") @pytest.mark.skipif(not is_windows_os(), reason="Tests Windows (not Posix) permissions.")
def test_create_secure_directory__perm_windows(test_path): def test_create_secure_directory__perm_windows(test_path):
import win32api # noqa: E402 import win32api
import win32security # noqa: E402 import win32security
FULL_CONTROL = 2032127 FULL_CONTROL = 2032127
ACE_TYPE_ALLOW = 0 ACE_TYPE_ALLOW = 0
create_secure_directory(test_path, create_parent_dirs=False) create_secure_directory(test_path)
user_sid, _, _ = win32security.LookupAccountName("", win32api.GetUserName()) user_sid, _, _ = win32security.LookupAccountName("", win32api.GetUserName())
security_descriptor = win32security.GetNamedSecurityInfo( security_descriptor = win32security.GetNamedSecurityInfo(