X-Git-Url: http://git.scottworley.com/auto-upgrade-with-pinch/blobdiff_plain/77278deedba83daa99f4ac0f5896570e728a63f3..13226f1c72df5771124e10f5de3648c3db0b587a:/modules/auto-upgrade.nix diff --git a/modules/auto-upgrade.nix b/modules/auto-upgrade.nix index a5c8b50..0977176 100644 --- a/modules/auto-upgrade.nix +++ b/modules/auto-upgrade.nix @@ -1,3 +1,9 @@ +# auto-upgrade-with-pinch: Secure managed NixOS updates +# +# This program is free software: you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by the +# Free Software Foundation, version 3. + { config, lib, pkgs, ... }: with lib; let @@ -59,6 +65,8 @@ let ''; auto-upgrade-script = pkgs.writeShellScript "auto-upgrade" '' + ${pkgs.coreutils}/bin/nice -n 17 \ + ${pkgs.util-linux}/bin/ionice -c 3 \ ${pkgs.util-linux}/bin/flock /run/auto-upgrade-with-pinch ${ pkgs.writeShellScript "auto-upgrade-with-lock-held" '' set -eo pipefail @@ -175,8 +183,10 @@ let # Build in_tmpdir hydrate ${config.system.build.nixos-rebuild}/bin/nixos-rebuild build while read user;do + pushd / hydrate /run/wrappers/bin/sudo -u "$user" \ ${pkgs.nix}/bin/nix-build --no-out-link '' -A "$(userenv_query "$user" .package)" + popd done < <( config_query '.userEnvironments | keys []' ) # Install