mirror of
https://github.com/containers/podman.git
synced 2025-08-06 19:44:14 +08:00
make podman-clean-transient.service work as user
In the user session there is no boot-complete.target so the Requires= fails. We do not need it and I am not sure if we need it for the root unit either but I deicded to keep it there to not change anything and for the user session we patch it out. I patched this in the Makefile, while we could try to define two different source files for that it would make the Makefile logic even more complicated. In particular as this file is a .in we would need to add it to PODMAN_GENERATED_UNIT_FILES and then somehow fix the loop. To much work IMO so the sed trick to patch the user file is simpler. Fixes #23790 Signed-off-by: Paul Holzinger <pholzing@redhat.com>
This commit is contained in:
7
Makefile
7
Makefile
@ -1000,6 +1000,13 @@ install.systemd: $(PODMAN_GENERATED_UNIT_FILES)
|
||||
install ${SELINUXOPT} -m 644 $$unit $(DESTDIR)${USERSYSTEMDDIR}/$$(basename $$unit); \
|
||||
install ${SELINUXOPT} -m 644 $$unit $(DESTDIR)${SYSTEMDDIR}/$$(basename $$unit); \
|
||||
done
|
||||
# HACK; as rootless this unit will not work due the requires on a non existing target
|
||||
# as the user session does not see system units. We could define two different units
|
||||
# but this seems much more complicated then this small fixup here.
|
||||
# https://github.com/containers/podman/issues/23790
|
||||
sed -i '/Requires=/d' $(DESTDIR)${USERSYSTEMDDIR}/podman-clean-transient.service
|
||||
sed -i '/After=/d' $(DESTDIR)${USERSYSTEMDDIR}/podman-clean-transient.service
|
||||
|
||||
# Important this unit should only be installed for the user session and is thus not added to the loop above.
|
||||
install ${SELINUXOPT} -m 644 contrib/systemd/user/podman-user-wait-network-online.service \
|
||||
$(DESTDIR)${USERSYSTEMDDIR}/podman-user-wait-network-online.service
|
||||
|
Reference in New Issue
Block a user