2017-07-23 16:05:46 +02:00
|
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
|
|
let
|
2017-07-23 18:56:37 +02:00
|
|
|
|
darwinChanges = ''
|
2017-08-01 22:59:19 +02:00
|
|
|
|
darwinChanges=/dev/null
|
2017-07-23 18:56:37 +02:00
|
|
|
|
if test -e /run/current-system/darwin-changes; then
|
2017-08-01 22:59:19 +02:00
|
|
|
|
darwinChanges=/run/current-system/darwin-changes
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
darwinChanges=$(diff --changed-group-format='%>' --unchanged-group-format= /run/current-system/darwin-changes $systemConfig/darwin-changes 2> /dev/null) || true
|
|
|
|
|
if test -n "$darwinChanges"; then
|
|
|
|
|
echo >&2
|
|
|
|
|
echo "[1;1mCHANGELOG[0m" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
echo "$darwinChanges" >&2
|
|
|
|
|
echo >&2
|
2017-07-23 18:56:37 +02:00
|
|
|
|
fi
|
|
|
|
|
'';
|
|
|
|
|
|
2018-01-13 22:50:48 +01:00
|
|
|
|
runLink = ''
|
|
|
|
|
if ! test -e /run; then
|
|
|
|
|
echo "[1;31merror: Directory /run does not exist, aborting activation[0m" >&2
|
|
|
|
|
echo "Create a symlink to /var/run with:" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
echo " sudo ln -s private/var/run /run" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
fi
|
|
|
|
|
'';
|
|
|
|
|
|
2017-07-23 16:05:46 +02:00
|
|
|
|
buildUsers = optionalString config.services.nix-daemon.enable ''
|
2017-07-23 19:07:04 +02:00
|
|
|
|
buildUser=$(dscl . -read /Groups/nixbld GroupMembership 2>&1 | awk '/^GroupMembership: / {print $2}') || true
|
2017-07-23 16:05:46 +02:00
|
|
|
|
if [ -z $buildUser ]; then
|
2017-07-23 17:23:09 +02:00
|
|
|
|
echo "[1;31merror: Using the nix-daemon requires build users, aborting activation[0m" >&2
|
|
|
|
|
echo "Create the build users or disable the daemon:" >&2
|
|
|
|
|
echo "$ ./bootstrap -u" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
echo "or set" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
echo " services.nix-daemon.enable = false;" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
fi
|
|
|
|
|
'';
|
|
|
|
|
|
2017-09-06 23:55:14 +02:00
|
|
|
|
nixChannels = ''
|
|
|
|
|
channelsLink=$(readlink "$HOME/.nix-defexpr/channels") || true
|
|
|
|
|
case "$channelsLink" in
|
|
|
|
|
*"$USER"*)
|
|
|
|
|
;;
|
|
|
|
|
"")
|
|
|
|
|
;;
|
|
|
|
|
*)
|
2018-01-13 22:50:48 +01:00
|
|
|
|
echo "[1;31merror: The ~/.nix-defexpr/channels symlink does not point your users channels, aborting activation[0m" >&2
|
2017-09-06 23:55:14 +02:00
|
|
|
|
echo "Running nix-channel will regenerate it" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
echo " rm ~/.nix-defexpr/channels" >&2
|
|
|
|
|
echo " nix-channel --update" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
;;
|
|
|
|
|
esac
|
|
|
|
|
'';
|
|
|
|
|
|
2018-01-13 19:44:26 +01:00
|
|
|
|
nixInstaller = ''
|
|
|
|
|
if grep -q 'etc/profile.d/nix-daemon.sh' /etc/profile; then
|
|
|
|
|
echo "[1;31merror: Found nix-daemon.sh reference in /etc/profile, aborting activation[0m" >&2
|
|
|
|
|
echo "This will override options like nix.nixPath because it runs later," >&2
|
|
|
|
|
echo "remove this snippet from /etc/profile:" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
echo " # Nix" >&2
|
|
|
|
|
echo " if [ -e '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' ]; then" >&2
|
|
|
|
|
echo " . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'" >&2
|
|
|
|
|
echo " fi" >&2
|
|
|
|
|
echo " # End Nix" >&2
|
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
fi
|
|
|
|
|
'';
|
|
|
|
|
|
2017-07-23 18:56:37 +02:00
|
|
|
|
nixPath = ''
|
2018-01-13 15:40:07 +01:00
|
|
|
|
darwinConfig=$(NIX_PATH=${concatStringsSep ":" config.nix.nixPath} nix-instantiate --eval -E '<darwin-config>' || echo '$HOME/.nixpkgs/darwin-configuration.nix') || true
|
2017-07-23 17:49:38 +02:00
|
|
|
|
if ! test -e "$darwinConfig"; then
|
2017-07-23 17:28:58 +02:00
|
|
|
|
echo "[1;31merror: Changed <darwin-config> but target does not exist, aborting activation[0m" >&2
|
2018-01-13 15:40:07 +01:00
|
|
|
|
echo "Create $darwinConfig or set nix.nixPath:" >&2
|
2017-07-23 17:28:58 +02:00
|
|
|
|
echo >&2
|
2018-01-13 15:40:07 +01:00
|
|
|
|
echo " nix.nixPath = [ \"darwin-config=$(nix-instantiate --eval -E '<darwin-config>' 2> /dev/null || echo '***')\" ];" >&2
|
2017-07-23 17:28:58 +02:00
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
fi
|
|
|
|
|
|
2017-07-24 19:29:31 +02:00
|
|
|
|
darwinPath=$(NIX_PATH=${concatStringsSep ":" config.nix.nixPath} nix-instantiate --eval -E '<darwin>') || true
|
2017-07-23 17:49:38 +02:00
|
|
|
|
if ! test -e "$darwinPath"; then
|
2017-07-23 17:23:09 +02:00
|
|
|
|
echo "[1;31merror: Changed <darwin> but target does not exist, aborting activation[0m" >&2
|
2017-08-07 20:09:59 +02:00
|
|
|
|
echo "Add the darwin repo as a channel or set nix.nixPath:" >&2
|
2017-09-06 23:37:34 +02:00
|
|
|
|
echo "$ nix-channel --add https://github.com/LnL7/nix-darwin/archive/master.tar.gz darwin" >&2
|
|
|
|
|
echo "$ nix-channel --update" >&2
|
2017-07-23 17:23:09 +02:00
|
|
|
|
echo >&2
|
|
|
|
|
echo "or set" >&2
|
|
|
|
|
echo >&2
|
2017-07-23 18:27:01 +02:00
|
|
|
|
echo " nix.nixPath = [ \"darwin=$(nix-instantiate --eval -E '<darwin>')\" ];" >&2
|
2017-07-23 17:23:09 +02:00
|
|
|
|
echo >&2
|
2017-07-23 16:05:46 +02:00
|
|
|
|
exit 2
|
|
|
|
|
fi
|
2017-07-23 17:49:38 +02:00
|
|
|
|
|
2017-07-24 19:29:31 +02:00
|
|
|
|
nixpkgsPath=$(NIX_PATH=${concatStringsSep ":" config.nix.nixPath} nix-instantiate --eval -E '<nixpkgs>') || true
|
2017-07-23 17:49:38 +02:00
|
|
|
|
if ! test -e "$nixpkgsPath"; then
|
|
|
|
|
echo "[1;31merror: Changed <nixpkgs> but target does not exist, aborting activation[0m" >&2
|
2017-08-07 20:09:59 +02:00
|
|
|
|
echo "Add a nixpkgs channel or set nix.nixPath:" >&2
|
2017-09-06 23:37:34 +02:00
|
|
|
|
echo "$ nix-channel --add http://nixos.org/channels/nixpkgs-unstable nixpkgs" >&2
|
|
|
|
|
echo "$ nix-channel --update" >&2
|
2017-07-23 17:49:38 +02:00
|
|
|
|
echo >&2
|
|
|
|
|
echo "or set" >&2
|
|
|
|
|
echo >&2
|
2017-07-24 19:31:57 +02:00
|
|
|
|
echo " nix.nixPath = [ \"nixpkgs=$(nix-instantiate --eval -E '<nixpkgs>')\" ];" >&2
|
2017-07-23 17:49:38 +02:00
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
fi
|
2017-07-23 16:05:46 +02:00
|
|
|
|
'';
|
2018-01-18 00:12:38 +01:00
|
|
|
|
|
|
|
|
|
nixStore = ''
|
|
|
|
|
if test -w /nix/var/nix/db -a ! -O /nix/store; then
|
|
|
|
|
echo >&2 "[1;31merror: the store is not owned by this user, but /nix/var/nix/db is writable[0m"
|
|
|
|
|
echo >&2 "If you are using the daemon:"
|
|
|
|
|
echo >&2
|
|
|
|
|
echo >&2 " sudo chown -R /nix/var/nix/db"
|
|
|
|
|
echo >&2
|
|
|
|
|
exit 2
|
|
|
|
|
fi
|
|
|
|
|
'';
|
2017-07-23 16:05:46 +02:00
|
|
|
|
in
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
options = {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
config = {
|
|
|
|
|
|
|
|
|
|
system.activationScripts.checks.text = ''
|
2017-07-23 18:56:37 +02:00
|
|
|
|
${darwinChanges}
|
2018-01-13 22:50:48 +01:00
|
|
|
|
${runLink}
|
2017-07-23 16:05:46 +02:00
|
|
|
|
${buildUsers}
|
2018-01-18 00:12:38 +01:00
|
|
|
|
${nixStore}
|
2017-09-06 23:55:14 +02:00
|
|
|
|
${nixChannels}
|
2018-01-13 19:44:26 +01:00
|
|
|
|
${nixInstaller}
|
2017-07-23 17:23:09 +02:00
|
|
|
|
${nixPath}
|
2017-07-23 18:02:08 +02:00
|
|
|
|
|
|
|
|
|
if test ''${checkActivation:-0} -eq 1; then
|
|
|
|
|
echo "ok" >&2
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
2017-07-23 16:05:46 +02:00
|
|
|
|
'';
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
}
|