feat(ops/nixos): Add 'rebuilder' helper script

This script rebuilds & activates system configuration based on the
hostname.

Currently since there is only one host this isn't particularly
interesting.
This commit is contained in:
Vincent Ambo 2020-01-04 22:48:52 +00:00
parent 63dc41bcf3
commit 85ee07457c
4 changed files with 33 additions and 5 deletions

View file

@ -38,6 +38,9 @@ case "${TARGET_TOOL}" in
age-keygen)
attr="third_party.age"
;;
rebuilder)
attr="ops.nixos.rebuilder"
;;
*)
echo "The tool '${TARGET_TOOL}' is currently not installed in this repository."
exit 1

1
bin/rebuilder Symbolic link
View file

@ -0,0 +1 @@
__dispatch.sh

View file

@ -9,9 +9,9 @@ System configuration lives in folders for each machine and a custom
fixed point evaluation (similar to standard NixOS module
configuration) is used to combine configuration together.
Building `ops.nixos.depot-switcher` yields a script that will
automatically build and activate the newest configuration based on the
current hostname.
Building `ops.nixos.rebuilder` yields a script that will automatically
build and activate the newest configuration based on the current
hostname.
## Configured hosts:

View file

@ -1,3 +1,4 @@
# TODO(tazjin): rename 'pkgs' -> 'depot'?
{ pkgs, ... }:
let
@ -9,7 +10,30 @@ let
foldl' lib.recursiveUpdate {} (map (c: c config) configs)
);
}).system;
in {
# TODO(tazjin): rename 'pkgs' -> 'depot'?
nuggetSystem = systemFor [ pkgs.ops.nixos.nugget ];
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;
}