diff --git a/backend/localplatform.py b/backend/localplatform.py index 43043ad03..5957f5d58 100644 --- a/backend/localplatform.py +++ b/backend/localplatform.py @@ -50,3 +50,20 @@ def get_selinux() -> bool: except FileNotFoundError: pass return False + +def chmod(path : str, permissions : int, recursive : bool = True) -> bool: + octal_permissions = int(str(permissions), 8) + + try: + if recursive: + for root, dirs, files in os.walk(path): + for d in dirs: + os.chmod(os.path.join(root, d), octal_permissions) + for d in files: + os.chmod(os.path.join(root, d), octal_permissions) + else: + os.chmod(path, octal_permissions) + except: + return False + + return True diff --git a/backend/localplatformlinux.py b/backend/localplatformlinux.py index 811db8a62..cdd089aaf 100644 --- a/backend/localplatformlinux.py +++ b/backend/localplatformlinux.py @@ -59,12 +59,6 @@ def chown(path : str, user : UserType = UserType.HOST_USER, recursive : bool = result = call(["chown", "-R", user_str, path] if recursive else ["chown", user_str, path]) return result == 0 -def chmod(path : str, permissions : int, recursive : bool = True) -> bool: - if _get_effective_user_id() != 0: - return True - result = call(["chmod", "-R", str(permissions), path] if recursive else ["chmod", str(permissions), path]) - return result == 0 - def folder_owner(path : str) -> UserType|None: user_owner = _get_user_owner(path) diff --git a/backend/localplatformwin.py b/backend/localplatformwin.py index b6bee330b..5c30482e1 100644 --- a/backend/localplatformwin.py +++ b/backend/localplatformwin.py @@ -4,9 +4,6 @@ def chown(path : str, user : UserType = UserType.HOST_USER, recursive : bool = True) -> bool: return True # Stubbed -def chmod(path : str, permissions : int, recursive : bool = True) -> bool: - return True # Stubbed - def folder_owner(path : str) -> UserType|None: return UserType.HOST_USER # Stubbed