]> git.ipfire.org Git - thirdparty/systemd.git/commit
user-util: rework get_user_creds()
authorLennart Poettering <lennart@poettering.net>
Thu, 2 Aug 2018 16:36:47 +0000 (18:36 +0200)
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Mon, 20 Aug 2018 13:58:21 +0000 (15:58 +0200)
commitfafff8f1ffdf24517921d7779c2a9eb89766df30
treea9f5bd4e5fb6e7680df49e9476b17366e58d06cf
parent163a035aa654aa16b5d26f6436b13b94fc75b3f2
user-util: rework get_user_creds()

Let's fold get_user_creds_clean() into get_user_creds(), and introduce a
flags argument for it to select "clean" behaviour. This flags parameter
also learns to other new flags:

- USER_CREDS_SYNTHESIZE_FALLBACK: in this mode the user records for
  root/nobody are only synthesized as fallback. Normally, the synthesized
  records take precedence over what is in the user database.  With this
  flag set this is reversed, and the user database takes precedence, and
  the synthesized records are only used if they are missing there. This
  flag should be set in cases where doing NSS is deemed safe, and where
  there's interest in knowing the correct shell, for example if the
  admin changed root's shell to zsh or suchlike.

- USER_CREDS_ALLOW_MISSING: if set, and a UID/GID is specified by
  numeric value, and there's no user/group record for it accept it
  anyway. This allows us to fix #9767

This then also ports all users to set the most appropriate flags.

Fixes: #9767
[zj: remove one isempty() call]
21 files changed:
src/basic/user-util.c
src/basic/user-util.h
src/core/execute.c
src/core/socket.c
src/coredump/coredump.c
src/login/loginctl.c
src/login/logind-core.c
src/login/user-runtime-dir.c
src/mount/mount-tool.c
src/network/netdev/tuntap.c
src/network/networkd.c
src/notify/notify.c
src/resolve/resolved.c
src/run/run.c
src/shared/condition.c
src/test/test-acl-util.c
src/test/test-ipcrm.c
src/test/test-user-util.c
src/timesync/timesyncd.c
src/tmpfiles/tmpfiles.c
src/udev/udev-rules.c