-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathMakefile
71 lines (47 loc) · 1.42 KB
/
Makefile
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
62
63
64
65
66
67
68
69
all: update
## Management
update: update-home update-os
update-os:
sudo -i sh -c 'cd nixfiles && git pull'
sudo -i sh -c 'cd nixos && make'
update-home: sync-pkgs sync update-env update-homemanager update-flatpak
update-env:
nix-env -u '*'
update-homemanager:
home-manager switch --flake .
update-flatpak:
flatpak update --appstream && flatpak update && flatpak uninstall --unused
outdated: sync
# TODO: sudo nixos-rebuild dry-build --upgrade
echo "Not implemented for flake"
sync:
nix flake update
sync-pkgs:
cd pkgs/nvim && nix flake update
clean:
sudo nix-collect-garbage --delete-older-than 7d
home-manager expire-generations "-7 days"
wireguard: /etc/nixos/.wireguard.key
wg genkey > "$@"
chmod 400 "$@"
sup: # What's new?
nix-shell -p nvd --run 'nvd diff $$(ls -dv /nix/var/nix/profiles/system-*-link | tail -2)'
## Setup
# Note: This is for old pre-flake stuff
HOST ?= example
KEYFILE ?= cryptroot.key
KEYSIZE ?= 4096
config: password configuration.nix
configuration.nix: hosts/${HOST}.nix
@echo "Generating configuration: HOST=${HOST}"
ln -s "$<" "$@"
password: .hashedPassword.nix
.hashedPassword.nix:
echo "\"$$(mkpasswd -m sha-512)\"" > "$@"
chmod 400 "$@"
${KEYFILE}:
dd if=/dev/urandom of="$@" bs=1 count=${KEYSIZE}
@echo "Add keyfile to encrypted volume: cryptsetup luksAddKey $$DEVICE ${KEYFILE}"
initrd.keys.gz: ${KEYFILE}
find $^ | cpio --quiet -H newc -o | gzip -9 -n > "$@"
chmod 400 "$@"