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) age-keygen)
attr="third_party.age" attr="third_party.age"
;; ;;
rebuilder)
attr="ops.nixos.rebuilder"
;;
*) *)
echo "The tool '${TARGET_TOOL}' is currently not installed in this repository." echo "The tool '${TARGET_TOOL}' is currently not installed in this repository."
exit 1 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 fixed point evaluation (similar to standard NixOS module
configuration) is used to combine configuration together. configuration) is used to combine configuration together.
Building `ops.nixos.depot-switcher` yields a script that will Building `ops.nixos.rebuilder` yields a script that will automatically
automatically build and activate the newest configuration based on the build and activate the newest configuration based on the current
current hostname. hostname.
## Configured hosts: ## Configured hosts:

View file

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