From 8f1b1ad846621aeb6fcd3b35d30534ff330353a1 Mon Sep 17 00:00:00 2001 From: InsanePrawn Date: Tue, 25 Feb 2025 22:46:40 +0100 Subject: [PATCH] wrapper_su_helper: pass PATH env var to child shell --- wrapper_su_helper.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) mode change 100755 => 100644 wrapper_su_helper.py diff --git a/wrapper_su_helper.py b/wrapper_su_helper.py old mode 100755 new mode 100644 index 7f8426c..7bf130b --- a/wrapper_su_helper.py +++ b/wrapper_su_helper.py @@ -24,7 +24,9 @@ def kupferbootstrap_su(cmd: list[str], uid: int = 1000, username: str = 'kupfer' run_cmd(['usermod', '-o', '-u', str(uid), username]).check_returncode() # type: ignore[union-attr] chown(home, username, recursive=False) logging.debug(f'wrapper_su_helper: running {cmd} as {repr(username)}') - env_inject = ['env', f'{WRAPPER_ENV_VAR}={os.environ[WRAPPER_ENV_VAR]}'] if WRAPPER_ENV_VAR in os.environ else [] + env_inject = ['env', f'PATH={os.environ["PATH"]}'] + if WRAPPER_ENV_VAR in os.environ: + env_inject.append(f'{WRAPPER_ENV_VAR}={os.environ[WRAPPER_ENV_VAR]}') su_cmd = ['sudo', *env_inject, 'su', '-P', username, '-c', flatten_shell_script(cmd, wrap_in_shell_quote=True, shell_quote_items=True)] result = run_cmd(su_cmd, attach_tty=True) assert isinstance(result, int)