2020-01-04 23:48:52 +01:00
|
|
|
# TODO(tazjin): rename 'pkgs' -> 'depot'?
|
2020-01-04 16:08:49 +01:00
|
|
|
{ pkgs, ... }:
|
|
|
|
|
|
|
|
let
|
2020-01-04 23:32:41 +01:00
|
|
|
inherit (pkgs) lib;
|
|
|
|
inherit (builtins) foldl';
|
|
|
|
|
|
|
|
systemFor = configs: (pkgs.third_party.nixos {
|
|
|
|
configuration = lib.fix(config:
|
|
|
|
foldl' lib.recursiveUpdate {} (map (c: c config) configs)
|
|
|
|
);
|
|
|
|
}).system;
|
2020-01-04 23:48:52 +01:00
|
|
|
|
2020-01-04 23:32:41 +01:00
|
|
|
nuggetSystem = systemFor [ pkgs.ops.nixos.nugget ];
|
2020-01-04 23:48:52 +01:00
|
|
|
|
|
|
|
rebuilder = pkgs.third_party.writeShellScriptBin "rebuilder" ''
|
|
|
|
set -ue
|
|
|
|
if [[ $EUID -ne 0 ]]; then
|
|
|
|
echo "Oh no! Only root is allowed to rebuild the system!" >&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
case $HOSTNAME in
|
|
|
|
nugget)
|
|
|
|
echo "Rebuilding NixOS for //ops/nixos/nugget"
|
|
|
|
system=$(nix-build -E '(import <depot> {}).ops.nixos.nuggetSystem' --no-out-link)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "$HOSTNAME is not a known NixOS host!" >&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
nix-env -p /nix/var/nix/profiles/system --set $system
|
|
|
|
$system/bin/switch-to-configuration switch
|
|
|
|
'';
|
|
|
|
in {
|
|
|
|
inherit nuggetSystem rebuilder;
|
2020-01-04 16:08:49 +01:00
|
|
|
}
|