Make lua scriplets more failsafe (boo#1219370)

OBS-URL: https://build.opensuse.org/package/show/Base:System/man?expand=0&rev=152
This commit is contained in:
Dr. Werner Fink 2024-02-08 12:03:35 +00:00 committed by Git OBS Bridge
parent 8d6649759f
commit e994d94907
2 changed files with 33 additions and 3 deletions

View File

@ -1,3 +1,8 @@
-------------------------------------------------------------------
Thu Feb 8 10:48:51 UTC 2024 - Dr. Werner Fink <werner@suse.de>
- Make lua scriplets more failsafe (boo#1219370)
------------------------------------------------------------------- -------------------------------------------------------------------
Fri Jan 26 09:26:57 UTC 2024 - Dr. Werner Fink <werner@suse.de> Fri Jan 26 09:26:57 UTC 2024 - Dr. Werner Fink <werner@suse.de>

View File

@ -286,10 +286,22 @@ end
%filetriggerin -p <lua> -- %{_mandir} %filetriggerin -p <lua> -- %{_mandir}
%endif %endif
%trigger_functions %trigger_functions
stat = posix.stat("/var/cache/man/index.db") stat = posix.stat("%{_localstatedir}/cache/man/index.db")
if stat then if stat then
execute("%{_bindir}/mandb", "--quiet") execute("%{_bindir}/mandb", "--quiet")
else else
domkdir = false
stat = posix.stat("%{_localstatedir}/cache/man")
if not stat then
domkdir = true
elseif not (stat.type == "directory") then
domkdir = true
os.remove("%{_localstatedir}/cache/man")
end
if domkdir then
posix.mkdir("%{_localstatedir}/cache/man")
posix.chown("%{_localstatedir}/cache/man", "man", "man")
end
execute("%{_bindir}/mandb", "--quiet", "--create") execute("%{_bindir}/mandb", "--quiet", "--create")
end end
@ -299,10 +311,22 @@ end
%filetriggerpostun -p <lua> -- %{_mandir} %filetriggerpostun -p <lua> -- %{_mandir}
%endif %endif
%trigger_functions %trigger_functions
stat = posix.stat("/var/cache/man/index.db") stat = posix.stat("%{_localstatedir}/cache/man/index.db")
if stat then if stat then
execute("%{_bindir}/mandb", "--quiet") execute("%{_bindir}/mandb", "--quiet")
else else
domkdir = false
stat = posix.stat("%{_localstatedir}/cache/man")
if not stat then
domkdir = true
elseif not (stat.type == "directory") then
domkdir = true
os.remove("%{_localstatedir}/cache/man")
end
if domkdir then
posix.mkdir("%{_localstatedir}/cache/man")
posix.chown("%{_localstatedir}/cache/man", "man", "man")
end
execute("%{_bindir}/mandb", "--quiet", "--create") execute("%{_bindir}/mandb", "--quiet", "--create")
end end
@ -332,7 +356,7 @@ then
fi fi
# Simply for systemdless containers # Simply for systemdless containers
getent group man > /dev/null || groupadd -r man getent group man > /dev/null || groupadd -r man
getent passwd man > /dev/null || useradd -r -g man -d /var/cache/man -s /sbin/nologin -c "Manual pages viewer" man getent passwd man > /dev/null || useradd -r -g man -d %{_localstatedir}/cache/man -s /sbin/nologin -c "Manual pages viewer" man
%post %post
%{fillup_only -an cron} %{fillup_only -an cron}
@ -367,6 +391,7 @@ if test ! -d %{_localstatedir}/cache/man
then then
# Simply for systemdless containers # Simply for systemdless containers
umask 022 umask 022
rm -f %{_localstatedir}/cache/man
mkdir -p %{_localstatedir}/cache/man mkdir -p %{_localstatedir}/cache/man
chown -R man:man %{_localstatedir}/cache/man chown -R man:man %{_localstatedir}/cache/man
fi fi