-
Notifications
You must be signed in to change notification settings - Fork 240
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
The --chroot option doesn't work well with SELinux off in-chroot #940
Comments
We (== rpm upstream) ran into this too: we'd like to use useradd/groupadd to create users into an otherwise practically empty chroot during the initial system install, but this selinux related logic prevents it. As @praiskup notes, just creating a fake enforcing file is enough to work around it:
This seems kinda counterproductive. Been there enough to know that SELinux and chroot aren't the best of friends, but few very few things are designed with a totally empty chroot in mind. In that case there are exactly two options: either use the info from the host, or disable. Disable is non-ambiguous, but obviously has other downsides. I wouldn't mind working on a patch if we can agree on the desireable way to handle it. FWIW the rpm sysusers issue would be sufficiently handled with an explicit flag of some sort (cli switch, env variable). |
I'm not a SELinux expert, am I to assume that |
Yes. |
In that case, my preferred option would be for SELinux to take this into account and provide an interface that we can use to see if SELinux is enabled in the chroot environment. This would also allow other projects to use the same interface to do the same thing. In case this is not possible shadow should check the |
Adding a new SELinux API (I assume you mean within the @pmatilai I observe that I also missed the comment in SELinuxProject/selinux#419 before, where @cgzones suggests calling |
rpm uses the SELinux API by itself - or rather, the plugin does. Unless I totally misremember something, it gets the labels from the host, so it's not really correct. Then again, there simply isn't anything else it could use when installing to an empty chroot. (sorry for the late reply, I completely missed the question initially and only stumbled here now by accident) |
No. That file indicates whether selinux is in enforcing mode, i.e. whether security denials are hard errors and not just warnings. This is not something that we care about here. libselinux has is_selinux_enabled(3), which checks whether
The man page explicitly says I don't think it makes sense to use the selinux state or config from the host system in a chroot. The whole point of a chroot is to have a different system, and even if the systems are broadly similar, creating labels that are 90% correct is not useful. It's worse than having no labels at all. If we're installing into an empty (or partially populated) chroot, then the only thing that makes sense is to ignore selinux. Once everything is in place, and we know that full config is available, we can run a relabel to set labels, if appropriate and desired. I think the useradd code should simply disable selinux support if |
@keszybz +1, just a comment to this:
Could anyone want the |
Consider installing a separate minimal chroot, and then running
useradd --root
(other shadow-utils utility):$ sudo dnf5 -y --use-host-config --installroot /tmp/newroot install /bin/sh $ sudo useradd jdoe --root /tmp/newroot useradd: failure while writing changes to /etc/passwd
I used GDB to detect what was going on. It is the call to
set_selinux_file_context ()
at file-descriptor-closing-time.The thing is that
set_selinux_file_context()
is called non-conditionally every time, and it asks foris_selinux_enabled()
- which provides the info about SELinux on-host, not in-chroot:shadow/lib/selinux.c
Lines 47 to 52 in 3e59e96
A further assumption that the
selabel_open()
,selabel_lookup_raw()
, etc. in-chroot will work, is wrong.There are further checks for permissive mode that make shadow utils not fail (in theory):
shadow/lib/selinux.c
Lines 66 to 68 in e367d11
But one would have to make sure that the
/tmp/newroot/sys/fs/selinux/enforce
file exists first, and contains 0.This problem is causing problems to Mock (RPM chrooted builds). We could fake the
/sys/fs/selinux/enforce
file for sure in Mock (we do other hacks to make things work), though this isn't the ideal solution; the mode in-chroot isn't really "permissive", it is supposed to be "disabled". So we should ideally not even attempt to callselabel_open()
, etc.While I see this probably isn't a mistake of shadow-utils (but rather chroot-unfriendly linbselinux API), I'm curious what is the best way out of this. Could we have a new
--no-selinux
option?Also, note that the manual pages are a bit misleading:
Note the note
No SELinux support.
This seems wrong. Theset_selinux_file_context()
is called with--prefix
exactly the same way as with--root
. It makes people think that--root
works better with SELinux, but that's not truth either.The text was updated successfully, but these errors were encountered: