2017-10-16 21:51:39 +03:00
|
|
|
# Only execute this file once per shell.
|
2023-12-29 09:14:53 +02:00
|
|
|
# This file is tested by tests/installer/default.nix.
|
2018-05-30 16:11:09 +03:00
|
|
|
if [ -n "${__ETC_PROFILE_NIX_SOURCED:-}" ]; then return; fi
|
2017-10-16 21:51:39 +03:00
|
|
|
__ETC_PROFILE_NIX_SOURCED=1
|
|
|
|
|
2021-11-17 22:35:21 +02:00
|
|
|
NIX_LINK=$HOME/.nix-profile
|
2023-02-28 20:09:55 +02:00
|
|
|
if [ -n "${XDG_STATE_HOME-}" ]; then
|
2021-11-17 22:35:21 +02:00
|
|
|
NIX_LINK_NEW="$XDG_STATE_HOME/nix/profile"
|
|
|
|
else
|
|
|
|
NIX_LINK_NEW=$HOME/.local/state/nix/profile
|
|
|
|
fi
|
2023-03-01 02:10:42 +02:00
|
|
|
if [ -e "$NIX_LINK_NEW" ]; then
|
2023-12-11 05:14:51 +02:00
|
|
|
if [ -t 2 ] && [ -e "$NIX_LINK" ]; then
|
2021-11-17 22:35:21 +02:00
|
|
|
warning="\033[1;35mwarning:\033[0m"
|
2023-12-11 05:14:51 +02:00
|
|
|
printf "$warning Both %s and legacy %s exist; using the former.\n" "$NIX_LINK_NEW" "$NIX_LINK" 1>&2
|
2021-11-17 22:35:21 +02:00
|
|
|
if [ "$(realpath "$NIX_LINK")" = "$(realpath "$NIX_LINK_NEW")" ]; then
|
|
|
|
printf " Since the profiles match, you can safely delete either of them.\n" 1>&2
|
|
|
|
else
|
|
|
|
# This should be an exceptionally rare occasion: the only way to get it would be to
|
|
|
|
# 1. Update to newer Nix;
|
|
|
|
# 2. Remove .nix-profile;
|
|
|
|
# 3. Set the $NIX_LINK_NEW to something other than the default user profile;
|
|
|
|
# 4. Roll back to older Nix.
|
|
|
|
# If someone did all that, they can probably figure out how to migrate the profile.
|
|
|
|
printf "$warning Profiles do not match. You should manually migrate from %s to %s.\n" "$NIX_LINK" "$NIX_LINK_NEW" 1>&2
|
|
|
|
fi
|
|
|
|
fi
|
2023-12-11 05:14:51 +02:00
|
|
|
NIX_LINK="$NIX_LINK_NEW"
|
2021-11-17 22:35:21 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
export NIX_PROFILES="@localstatedir@/nix/profiles/default $NIX_LINK"
|
2017-10-16 21:51:39 +03:00
|
|
|
|
2023-09-15 20:49:30 +03:00
|
|
|
# Populate bash completions, .desktop files, etc
|
2023-11-21 15:49:48 +02:00
|
|
|
if [ -z "${XDG_DATA_DIRS-}" ]; then
|
2023-09-15 20:49:30 +03:00
|
|
|
# According to XDG spec the default is /usr/local/share:/usr/share, don't set something that prevents that default
|
|
|
|
export XDG_DATA_DIRS="/usr/local/share:/usr/share:$NIX_LINK/share:/nix/var/nix/profiles/default/share"
|
|
|
|
else
|
|
|
|
export XDG_DATA_DIRS="$XDG_DATA_DIRS:$NIX_LINK/share:/nix/var/nix/profiles/default/share"
|
|
|
|
fi
|
|
|
|
|
2018-05-25 22:28:26 +03:00
|
|
|
# Set $NIX_SSL_CERT_FILE so that Nixpkgs applications like curl work.
|
2021-11-18 19:33:13 +02:00
|
|
|
if [ -n "${NIX_SSL_CERT_FILE:-}" ]; then
|
2018-05-25 22:28:26 +03:00
|
|
|
: # Allow users to override the NIX_SSL_CERT_FILE
|
|
|
|
elif [ -e /etc/ssl/certs/ca-certificates.crt ]; then # NixOS, Ubuntu, Debian, Gentoo, Arch
|
|
|
|
export NIX_SSL_CERT_FILE=/etc/ssl/certs/ca-certificates.crt
|
|
|
|
elif [ -e /etc/ssl/ca-bundle.pem ]; then # openSUSE Tumbleweed
|
|
|
|
export NIX_SSL_CERT_FILE=/etc/ssl/ca-bundle.pem
|
|
|
|
elif [ -e /etc/ssl/certs/ca-bundle.crt ]; then # Old NixOS
|
|
|
|
export NIX_SSL_CERT_FILE=/etc/ssl/certs/ca-bundle.crt
|
|
|
|
elif [ -e /etc/pki/tls/certs/ca-bundle.crt ]; then # Fedora, CentOS
|
|
|
|
export NIX_SSL_CERT_FILE=/etc/pki/tls/certs/ca-bundle.crt
|
2018-09-20 02:33:35 +03:00
|
|
|
else
|
|
|
|
# Fall back to what is in the nix profiles, favouring whatever is defined last.
|
2020-10-20 23:03:38 +03:00
|
|
|
check_nix_profiles() {
|
2024-08-16 03:56:05 +03:00
|
|
|
if [ -n "${ZSH_VERSION:-}" ]; then
|
2020-10-20 23:03:38 +03:00
|
|
|
# Zsh by default doesn't split words in unquoted parameter expansion.
|
|
|
|
# Set local_options for these options to be reverted at the end of the function
|
|
|
|
# and shwordsplit to force splitting words in $NIX_PROFILES below.
|
|
|
|
setopt local_options shwordsplit
|
2018-09-20 02:33:35 +03:00
|
|
|
fi
|
2020-10-20 23:03:38 +03:00
|
|
|
for i in $NIX_PROFILES; do
|
2021-11-18 19:33:13 +02:00
|
|
|
if [ -e "$i/etc/ssl/certs/ca-bundle.crt" ]; then
|
2020-10-20 23:03:38 +03:00
|
|
|
export NIX_SSL_CERT_FILE=$i/etc/ssl/certs/ca-bundle.crt
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
check_nix_profiles
|
|
|
|
unset -f check_nix_profiles
|
2018-05-25 22:28:26 +03:00
|
|
|
fi
|
|
|
|
|
2021-11-17 22:35:21 +02:00
|
|
|
export PATH="$NIX_LINK/bin:@localstatedir@/nix/profiles/default/bin:$PATH"
|
2024-04-06 17:26:29 +03:00
|
|
|
unset NIX_LINK NIX_LINK_NEW
|