2020-06-13 22:52:20 +02:00
|
|
|
# TODO(tazjin): Generalise this and move to //ops/nixos
|
2020-02-21 13:47:29 +01:00
|
|
|
{ depot, lib, ... }:
|
2020-01-04 16:08:49 +01:00
|
|
|
|
|
|
|
let
|
2020-01-04 23:32:41 +01:00
|
|
|
inherit (builtins) foldl';
|
|
|
|
|
2020-02-21 13:47:29 +01:00
|
|
|
systemFor = configs: (depot.third_party.nixos {
|
2020-01-04 23:32:41 +01:00
|
|
|
configuration = lib.fix(config:
|
|
|
|
foldl' lib.recursiveUpdate {} (map (c: c config) configs)
|
|
|
|
);
|
|
|
|
}).system;
|
2020-01-04 23:48:52 +01:00
|
|
|
|
2020-06-13 22:52:20 +02:00
|
|
|
caseFor = hostname: ''
|
|
|
|
${hostname})
|
|
|
|
echo "Rebuilding NixOS for //users/tazjin/nixos/${hostname}"
|
|
|
|
system=$(nix-build -E '(import <depot> {}).users.tazjin.nixos.${hostname}System' --no-out-link)
|
|
|
|
;;
|
|
|
|
'';
|
|
|
|
|
2020-02-21 13:47:29 +01:00
|
|
|
rebuilder = depot.third_party.writeShellScriptBin "rebuilder" ''
|
2020-01-04 23:48:52 +01:00
|
|
|
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
|
2020-06-13 22:52:20 +02:00
|
|
|
${caseFor "camden"}
|
|
|
|
${caseFor "frog"}
|
2020-01-04 23:48:52 +01:00
|
|
|
*)
|
|
|
|
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 {
|
2020-02-11 16:41:00 +01:00
|
|
|
inherit rebuilder;
|
|
|
|
|
2020-06-13 22:52:20 +02:00
|
|
|
camdenSystem = systemFor [ depot.users.tazjin.nixos.camden ];
|
|
|
|
frogSystem = systemFor [ depot.users.tazjin.nixos.frog ];
|
2020-01-04 16:08:49 +01:00
|
|
|
}
|