[Bug 1771858] Re: /snap/bin not in default PATH for units, snapd should ship system-environment-generators to inject /snap/bin into $PATH
Seth Arnold
1771858 at bugs.launchpad.net
Sat May 19 01:21:56 UTC 2018
On Fri, May 18, 2018 at 06:01:19PM -0000, Oliver Grawert wrote:
> well, my subtle hint would point to simply add it to /etc/environment
> here, which would globally cover for everything, would allow us to drop
Note that /etc/environment is only used by PAM-aware services that have
been configured to use pam_env in the corresponding /etc/pam.d/ files.
systemd will not use PAM when launching services.
This might still match your idea of "everything" but I wanted to make
sure.
Thanks
--
You received this bug notification because you are a member of Ubuntu
Foundations Bugs, which is subscribed to systemd in Ubuntu.
https://bugs.launchpad.net/bugs/1771858
Title:
/snap/bin not in default PATH for units, snapd should ship system-
environment-generators to inject /snap/bin into $PATH
Status in snapd package in Ubuntu:
New
Status in systemd package in Ubuntu:
New
Status in snapd source package in Xenial:
New
Status in systemd source package in Xenial:
Confirmed
Status in snapd source package in Bionic:
New
Status in systemd source package in Bionic:
Won't Fix
Status in snapd source package in Cosmic:
New
Status in systemd source package in Cosmic:
Won't Fix
Bug description:
This means that software installed via snap isn't transparently
available for units to use. As snaps are first-class citizens in
Ubuntu, we should update the PATH.
Specifically, this is evident by e.g. $ systemd-run env. Or any other
daemons that spawn shell scripts (e.g. cloud-init metadata acquired
shell hooks, etc.).
Since v232 systemd provides support for environment generators, snapd
should package/ship a snippet that injects the correct snapd path into
systemd environment.
E.g.:
$ sudo mkdir -p /usr/lib/systemd/system-environment-generators
$ printf '#!/bin/sh\nPATH=$PATH:/snap/bin\n' | \
sudo tee /usr/lib/systemd/system-environment-generators/90-snapd
Something similar can be done for user-environment-generators too.
Note that user-environment-generators can generate unique variables
per user.
Note please use /usr/lib path, as it appears that /lib/systemd path is
not working atm. Will check if that needs to be fixed up.
systemd in xenial does not support system-environment-generators, thus
we probably need to upload a patch to change the DEFAULT_PATH compiled
in default there.
[Testcase]
$ systemd-run /usr/bin/env
$ journalctl -e | grep PATH
Output should contain /snap/bin
To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/snapd/+bug/1771858/+subscriptions
More information about the foundations-bugs
mailing list