mirror of
https://github.com/NixOS/nix
synced 2024-09-19 10:50:24 -04:00
install-multi-user: fix when sudo is alias to doas
In my system, sudo is a symlink to doas. The thing is that they behave differently:: $ sudo KEY=value echo good good $ doas KEY=value echo bad doas: KEY=value: command not found The syntax of K=v before a command is only valid in a shell. But from what I understand, doas runs the command directly. So the fix is to prepend with "env": $ doas env KEY=value echo good good
This commit is contained in:
parent
1632f08ea2
commit
a9e01f429f
|
@ -831,7 +831,7 @@ EOF
|
||||||
fi
|
fi
|
||||||
|
|
||||||
_sudo "to load data for the first time in to the Nix Database" \
|
_sudo "to load data for the first time in to the Nix Database" \
|
||||||
HOME="$ROOT_HOME" "$NIX_INSTALLED_NIX/bin/nix-store" --load-db < ./.reginfo
|
env HOME="$ROOT_HOME" "$NIX_INSTALLED_NIX/bin/nix-store" --load-db < ./.reginfo
|
||||||
|
|
||||||
echo " Just finished getting the nix database ready."
|
echo " Just finished getting the nix database ready."
|
||||||
)
|
)
|
||||||
|
@ -921,11 +921,11 @@ cert_in_store() {
|
||||||
setup_default_profile() {
|
setup_default_profile() {
|
||||||
task "Setting up the default profile"
|
task "Setting up the default profile"
|
||||||
_sudo "to install a bootstrapping Nix in to the default profile" \
|
_sudo "to install a bootstrapping Nix in to the default profile" \
|
||||||
HOME="$ROOT_HOME" "$NIX_INSTALLED_NIX/bin/nix-env" -i "$NIX_INSTALLED_NIX"
|
env HOME="$ROOT_HOME" "$NIX_INSTALLED_NIX/bin/nix-env" -i "$NIX_INSTALLED_NIX"
|
||||||
|
|
||||||
if [ -z "${NIX_SSL_CERT_FILE:-}" ] || ! [ -f "${NIX_SSL_CERT_FILE:-}" ] || cert_in_store; then
|
if [ -z "${NIX_SSL_CERT_FILE:-}" ] || ! [ -f "${NIX_SSL_CERT_FILE:-}" ] || cert_in_store; then
|
||||||
_sudo "to install a bootstrapping SSL certificate just for Nix in to the default profile" \
|
_sudo "to install a bootstrapping SSL certificate just for Nix in to the default profile" \
|
||||||
HOME="$ROOT_HOME" "$NIX_INSTALLED_NIX/bin/nix-env" -i "$NIX_INSTALLED_CACERT"
|
env HOME="$ROOT_HOME" "$NIX_INSTALLED_NIX/bin/nix-env" -i "$NIX_INSTALLED_CACERT"
|
||||||
export NIX_SSL_CERT_FILE=/nix/var/nix/profiles/default/etc/ssl/certs/ca-bundle.crt
|
export NIX_SSL_CERT_FILE=/nix/var/nix/profiles/default/etc/ssl/certs/ca-bundle.crt
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -934,7 +934,7 @@ setup_default_profile() {
|
||||||
# otherwise it will be lost in environments where sudo doesn't pass
|
# otherwise it will be lost in environments where sudo doesn't pass
|
||||||
# all the environment variables by default.
|
# all the environment variables by default.
|
||||||
if ! _sudo "to update the default channel in the default profile" \
|
if ! _sudo "to update the default channel in the default profile" \
|
||||||
HOME="$ROOT_HOME" NIX_SSL_CERT_FILE="$NIX_SSL_CERT_FILE" "$NIX_INSTALLED_NIX/bin/nix-channel" --update nixpkgs; then
|
env HOME="$ROOT_HOME" NIX_SSL_CERT_FILE="$NIX_SSL_CERT_FILE" "$NIX_INSTALLED_NIX/bin/nix-channel" --update nixpkgs; then
|
||||||
reminder <<EOF
|
reminder <<EOF
|
||||||
I had trouble fetching the nixpkgs channel (are you offline?)
|
I had trouble fetching the nixpkgs channel (are you offline?)
|
||||||
To try again later, run: sudo -i nix-channel --update nixpkgs
|
To try again later, run: sudo -i nix-channel --update nixpkgs
|
||||||
|
|
Loading…
Reference in a new issue