GNU bug report logs -
#30728
guix-install.sh doesn't work if run with "sudo"
Previous Next
Full log
View this message in rfc822 format
Hi Chris,
Chris Marusich <cmmarusich <at> gmail.com> writes:
> Clément Lassieur <clement <at> lassieur.org> writes:
>
>> Clément Lassieur <clement <at> lassieur.org> writes:
>>
>>> Hi,
>>>
>>> My system is Ubuntu 16.04.
>>>
>>> I ran './guix-install.sh' and got the message: "This script must be run
>>> as root.". So I ran 'sudo ./guix-install.sh' and got an error message
>>> saying that:
>>>
>>> GUIX_PROFILE="${HOME}/.guix-profile"
>>> source "${GUIX_PROFILE}/etc/profile"
>>>
>>> the 'source' command doesn't work because ${GUIX_PROFILE} was never
>>> created, ${HOME} being /home/clement, not /root.
>>>
>>> To recover from this I had to manually delete /var/guix and /gnu, log as
>>> root with 'su', and start again.
>>>
>>> Clément
>>
>> I believe the script should install Guix in the user's home directory,
>> not in ~root.
>
> The manual says (see: (guix) Binary Installation):
>
> 3. Make ‘root’’s profile available under ‘~/.guix-profile’:
>
> # ln -sf /var/guix/profiles/per-user/root/guix-profile \
> ~root/.guix-profile
I think the manual is wrong here. This only makes sense if the user is
'root'. Otherwise, the user would expect Guix to be installed in their
home, not in root's home. We could use the HOME and USER environment
variables like this:
# ln -sf /var/guix/profiles/per-user/$USER/guix-profile $HOME/.guix-profile
Thus, even if 'sudo' decides to change these environment variables, it
will still be consistent.
> Source ‘etc/profile’ to augment ‘PATH’ and other relevant
> environment variables:
>
> # GUIX_PROFILE=$HOME/.guix-profile ; \
> source $GUIX_PROFILE/etc/profile
>
> I believe the expectation here is that $HOME will expand to root's home
> directory. Look at the previous ln invocation: we set up a symlink for
> the .guix-profile in root's home directory, so it's pretty clear that
> $HOME/.guix-profile is supposed to point to that profile.
>
> I think there is a tacit assumption in the manual and the
> guix-install.sh script that the HOME environment variable will refer to
> root's home directory, which is not always true. For example, on
> current Ubuntu, if you run sudo with no arguments, you will find that
> the HOME environment variable still points to your unprivileged user's
> home directory, not to root's home directory. This is because sudo can
> be configured in many ways, and on Ubuntu, they have chosen to configure
> it in that way. On other systems, it might behave differently.
This bug report was last modified 7 years and 55 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.