On 12/01/17 21:23, Stephen Smalley wrote:
On Thu, 2017-01-12 at 20:47 +0000, Alan Jenkins wrote:
On 12/01/17 20:01, Stephen Smalley wrote:
On Wed, 2017-01-11 at 12:41 +0000, Alan Jenkins wrote:
fixfiles links to restorecon. However if you start with
restorecon
"restore file(s) default SELinux security contexts", you can
easily
miss the fixfiles script. fixfiles is more generally useful than
`restorecon -R`. For example `restorecon -R /` is not as good
as
`fixfiles restore`, because the restorecon command will try to
relabel
`/sys` and fail noisily.
Thanks, applied both patches.
yay!
Wondering though about the behavior
you describe above; restorecon -R /sys only issues one error
message
for me and otherwise works fine,
# restorecon -R /sys
Could not set context for /sys/fs/cgroup: Read-only file system
It turned out fixfiles also generated similar noise. I suspect this
involved `-v` (in both cases), sorry.
Fedora Workstation 25:
"fixfiles spams warnings about debugfs. (docs say it only touches
"real" filesystems!)" https://bugzilla.redhat.com/show_bug.cgi?id=141
2747
Perhaps the root cause is actually the same. I still prefer the
messages from fixfiles though. It explicitly detected conflicting
labels on hardlinks
https://bugzilla.redhat.com/show_bug.cgi?id=1411371
and informed me in advance when it decided to traverse and relabel
five of my virtual filesystems
Checking / /boot /dev /dev/hugepages /dev/mqueue /dev/pts /dev/shm
/home /run /run/user/1000 /run/user/1001 /run/user/42 /sys
/sys/fs/pstore /sys/kernel/debug /tmp
(I doubt devtmpfs files are _intended_ to be labeled like this
either. OTOH the stupidity doesn't seem to affect it, so I won't
complain there).
By default, it includes any filesystem with the seclabel mount option
from /proc/mounts; this is a kernel-generated option that indicates
that the filesystem is known to support setting of security labels by
userspace. restorecon (and setfiles) can be further instructed to skip
specific directories via the -e option. fixfiles is just a wrapper
script around setfiles and/or restorecon depending on its options.
setfiles was the original SELinux filesystem labeling utility,
oriented to labeling a list of filesystems based on a specified
file_contexts configuration, potentially even on a SELinux-disabled
host. fixfiles and restorecon were later additions by Red Hat as more
user-friendly options, and then still later restorecon kept growing in
functionality and duplicating setfiles that we coalesced them
(restorecon is just a link that alters the default options and command-
line interface).
setfiles walks a filesystem at a time, which facilitates the hard link
conflict detection logic. restorecon in contrast just recurses a
directory tree (with -R) and doesn't care about filesystem boundaries,
so if we wanted to turn on hard link conflict detection for it, we'd
need to augment that logic to save the device numbers too. Possible
but hasn't been a priority.
Ok.
My main puzzle here[*] is why `fixfiles` handles sysfs (/sys/) fine, but
then there's floods of warnings about debugfs (/sys/kernel/debug/). The
same seems to happen with /dev/ being fine, but not the other virtual
fs's with seclabel which are mounted in subdirectories of /dev/.
What frustrates me is that `fixfiles check` generates this flood of
messages even immediately after `fixfiles restore`. (Or equivalently,
that `fixfiles restore -v` does not converge to a smaller number of
messages).
My use case was to install the latest version of some software from
source (fwupd), apply the labels expected by the distribution policy,
and also check what that involved.
I learnt about fixfiles from /usr/libexec/selinux/selinux-autorelabel.
(I notice the autorelabel script "handles" any messages by redirecting
to /dev/null. But, it's using `fixfiles restore` without `-v`, which
doesn't generate these warnings. It seems it would also miss out on the
nice percentage progress indicator. Weird).
Thanks
Alan
[*] Ok, I was also surprised that fixfiles dug into my home directory.
It's happy with `touch /home/alan-sysop/t` (user_home_t), but after I
"move to wastebasket", it complains the file needs to marked as
data_home_t. No idea what happens if you relabel and then try to
restore files from the wastebasket, e.g. `.ssh` or `public_html`. But
then `public_html` doesn't seem to get labeled when I create it either.
Clearly there's something I don't understand.
_______________________________________________
Selinux mailing list
Selinux@xxxxxxxxxxxxx
To unsubscribe, send email to Selinux-leave@xxxxxxxxxxxxx.
To get help, send an email containing "help" to Selinux-request@xxxxxxxxxxxxx.