28f9992604
Fixes: $ shellcheck -S warning selinux-autorelabel-generator.sh In selinux-autorelabel-generator.sh line 22: source /etc/selinux/config ^------------------------^ SC3046 (warning): In POSIX sh, 'source' in place of '.' is undefined. For more information: https://www.shellcheck.net/wiki/SC3046 -- In POSIX sh, 'source' in place of... https://bugzilla.redhat.com/show_bug.cgi?id=2210593
39 lines
1003 B
Bash
39 lines
1003 B
Bash
#!/bin/bash
|
|
|
|
# This systemd.generator(7) detects if SELinux is running and if the
|
|
# user requested an autorelabel, and if so sets the default target to
|
|
# selinux-autorelabel.target, which will cause the filesystem to be
|
|
# relabelled and then the system will reboot again and boot into the
|
|
# real default target.
|
|
|
|
PATH=/usr/sbin:$PATH
|
|
unitdir=/usr/lib/systemd/system
|
|
|
|
# If invoked with no arguments (for testing) write to /tmp.
|
|
earlydir="/tmp"
|
|
if [ -n "$2" ]; then
|
|
earlydir="$2"
|
|
fi
|
|
|
|
set_target ()
|
|
{
|
|
ln -sf "$unitdir/selinux-autorelabel.target" "$earlydir/default.target"
|
|
AUTORELABEL="1"
|
|
source /etc/selinux/config
|
|
if [ "$AUTORELABEL" = "0" ]; then
|
|
mkdir -p "$earlydir/selinux-autorelabel.service.d"
|
|
cat > "$earlydir/selinux-autorelabel.service.d/tty.conf" <<EOF
|
|
[Service]
|
|
StandardInput=tty
|
|
EOF
|
|
fi
|
|
}
|
|
|
|
if selinuxenabled; then
|
|
if test -f /.autorelabel; then
|
|
set_target
|
|
elif grep -sqE "\bautorelabel\b" /proc/cmdline; then
|
|
set_target
|
|
fi
|
|
fi
|