blob: a9eb4a130a781e08f7d8bb7bafb671c95fe83044 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
args @ { depot, pkgs, ... }:
rec {
chupacabra = import ./machines/chupacabra.nix;
chupacabraSystem = (pkgs.nixos {
configuration = chupacabra;
}).system;
mugwump = import ./machines/mugwump.nix;
mugwumpSystem = (pkgs.nixos {
configuration = mugwump;
}).system;
yeren = import ./machines/yeren.nix;
yerenSystem = (pkgs.nixos {
configuration = yeren;
}).system;
iso = import ./iso.nix args;
# Build chupacabra in CI
meta.targets = [
"chupacabraSystem"
"mugwumpSystem"
"yerenSystem"
"iso"
];
rebuilder =
let
depotPath = "/home/grfn/code/depot";
caseFor = hostname: ''
${hostname})
echo "Rebuilding NixOS for //users/glittershark/nixos/${hostname}"
system=$(nix-build -E '(import ${depotPath} {}).users.glittershark.system.system.${hostname}' --no-out-link)
;;
'';
in depot.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
${caseFor "chupacabra"}
*)
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
'';
}
|