diff options
author | Christian Breunig <christian@breunig.cc> | 2023-12-30 10:56:22 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-12-30 10:56:22 +0100 |
commit | e70e7dba736fec27145f2b4abeb70278dce0deb9 (patch) | |
tree | ddde9726bf950a6f72032161879f8d73d9b92e12 /src/conf_mode | |
parent | 0591d03464248c3a50516cd00b04989b3f16f1e5 (diff) | |
parent | 3c990f49e2bf9347bd2cc478995baa995ee822fd (diff) | |
download | vyos-1x-e70e7dba736fec27145f2b4abeb70278dce0deb9.tar.gz vyos-1x-e70e7dba736fec27145f2b4abeb70278dce0deb9.zip |
Merge pull request #2716 from c-po/login-t5875
login: T5875: restore home directory permissions when re-adding user account
Diffstat (limited to 'src/conf_mode')
-rwxr-xr-x | src/conf_mode/system-login.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/conf_mode/system-login.py b/src/conf_mode/system-login.py index aeac82462..f34575aff 100755 --- a/src/conf_mode/system-login.py +++ b/src/conf_mode/system-login.py @@ -29,6 +29,7 @@ from vyos.defaults import directories from vyos.template import render from vyos.template import is_ipv4 from vyos.utils.dict import dict_search +from vyos.utils.file import chown from vyos.utils.process import cmd from vyos.utils.process import call from vyos.utils.process import rc_cmd @@ -334,13 +335,16 @@ def apply(login): command += f' --groups frr,frrvty,vyattacfg,sudo,adm,dip,disk,_kea {user}' try: cmd(command) - # we should not rely on the value stored in # user_config['home_directory'], as a crazy user will choose # username root or any other system user which will fail. # # XXX: Should we deny using root at all? home_dir = getpwnam(user).pw_dir + # T5875: ensure UID is properly set on home directory if user is re-added + if os.path.exists(home_dir): + chown(home_dir, user=user, recursive=True) + render(f'{home_dir}/.ssh/authorized_keys', 'login/authorized_keys.j2', user_config, permission=0o600, formater=lambda _: _.replace(""", '"'), |