]> git.immae.eu Git - perso/Immae/Config/Nix.git/blame - nixops/Makefile
Refactor secrets handling
[perso/Immae/Config/Nix.git] / nixops / Makefile
CommitLineData
da28a4e2
IB
1ifndef NIXOPS_ENV_LOADED
2 $(error "Please load environment with direnv")
3endif
4
4506dbe5
IB
5###### Current channel information
6nix-info:
7 @version=$$(nix eval --raw nixpkgs.lib.version) && \
8 mainversion=$$(echo $$version | cut -d"." -f -2) && \
9 echo "https://releases.nixos.org/nixos/$$mainversion/nixos-$$version/nixexprs.tar.xz" && \
af3aeef2 10 nix-instantiate --find-file nixpkgs
4506dbe5
IB
11.PHONY: nix-info
12
13###### Initial setup
c79bb682
IB
14setup:
15 ./scripts/setup
4506dbe5 16.PHONY: setup
c79bb682 17
34abd6af
IB
18###### Morph regular tasks
19PROFILE=/nix/var/nix/profiles/per-user/immae/morph/immaeEu
7ff0f7be 20TARGET ?=
34abd6af 21MORPH_ARGS ?=
7ff0f7be 22ifdef TARGET
34abd6af
IB
23 # multiple targets: --on="{machine1,machine2}" (works with * glob too)
24 override MORPH_ARGS +=--on=$(TARGET)
7ff0f7be
IB
25endif
26SSH_ARGS ?=
27
1052bfda 28edit_env:
282c67a1
IB
29 $(EDITOR) secrets/environment.nix || true
30 git -C secrets add environment.nix || true
31 git -C secrets commit -m "Edit environment.nix" environment.nix || true
32
33edit_vars:
34 sops secrets/vars.yml || true
35 git -C secrets add vars.yml || true
36 git -C secrets commit -m "Edit password for vars.yml using sops." vars.yml || true
1052bfda 37
c79bb682 38ssh-eldiron:
34abd6af 39 ./scripts/with_env bash -c 'ssh -i $$SSH_IDENTITY_FILE root@eldiron $(SSH_ARGS)'
c79bb682 40
8a304ef4 41ssh-dilion:
34abd6af 42 ./scripts/with_env bash -c 'ssh -i $$SSH_IDENTITY_FILE root@dilion $(SSH_ARGS)'
8a304ef4 43
ddaa9caf 44ssh-backup-2:
34abd6af 45 ./scripts/with_env bash -c 'ssh -i $$SSH_IDENTITY_FILE root@backup-2 $(SSH_ARGS)'
ddaa9caf 46
e820134d 47ssh-monitoring-1:
34abd6af 48 ./scripts/with_env bash -c 'ssh -i $$SSH_IDENTITY_FILE root@monitoring-1 $(SSH_ARGS)'
c79bb682 49
75489e72
IB
50ssh-4c:
51 ./scripts/with_env bash -c 'ssh -i $$SSH_IDENTITY_FILE root@quatresaisons $(SSH_ARGS)'
52
c79bb682 53debug:
34abd6af 54 ./scripts/with_env morph build --show-trace default.nix $(MORPH_ARGS)
c79bb682
IB
55
56build:
34abd6af 57 ./scripts/with_env morph build default.nix $(MORPH_ARGS)
c79bb682 58
70712d46
IB
59dry-run:
60 ./scripts/with_env morph build --dry-run default.nix $(MORPH_ARGS)
61
c79bb682 62upload:
34abd6af 63 ./scripts/with_env morph push default.nix $(MORPH_ARGS)
c79bb682
IB
64
65deploy:
34abd6af
IB
66 ./scripts/with_env morph deploy default.nix switch --keep-result --upload-secrets $(MORPH_ARGS)
67 nix-env -p $(PROFILE) --set .gcroots/default.nix
1618010c 68
0c9152bd
IB
69next-boot:
70 ./scripts/with_env morph deploy default.nix boot --keep-result --upload-secrets $(MORPH_ARGS)
71 nix-env -p $(PROFILE) --set .gcroots/default.nix
72
4506dbe5 73deploy-reboot:
34abd6af 74 ./scripts/with_env morph deploy default.nix boot --reboot --upload-secrets $(MORPH_ARGS)
c79bb682 75
34abd6af 76.PHONY: ssh-eldiron ssh-dilion ssh-monitoring-1 ssh-backup-2 debug build upload deploy deploy-reboot
c79bb682 77
4506dbe5 78###### Cleanup generations and garbage collection
c79bb682
IB
79GEN ?= "+3"
80
81list-generations:
34abd6af
IB
82 nix-env -p $(PROFILE) --list-generations
83 $(MAKE) ssh-eldiron SSH_ARGS="nix-env -p /nix/var/nix/profiles/system --list-generations"
4506dbe5 84.PHONY: list-generations
c79bb682
IB
85
86delete-generations:
282c67a1
IB
87 @echo "making sure that a complete build is done before cleaning up"
88 $(MAKE) build MORPH_ARGS=--keep-result
34abd6af
IB
89 nix-env -p $(PROFILE) --delete-generations $(GEN)
90 $(MAKE) ssh-eldiron SSH_ARGS="nix-env -p /nix/var/nix/profiles/system --delete-generations $(GEN)"
91 $(MAKE) ssh-dilion SSH_ARGS="nix-env -p /nix/var/nix/profiles/system --delete-generations $(GEN)"
92 $(MAKE) ssh-backup-2 SSH_ARGS="nix-env -p /nix/var/nix/profiles/system --delete-generations $(GEN)"
93 $(MAKE) ssh-monitoring-1 SSH_ARGS="nix-env -p /nix/var/nix/profiles/system --delete-generations $(GEN)"
4506dbe5 94.PHONY: delete-generations
c79bb682
IB
95
96cleanup: delete-generations
97 nix-store --gc
34abd6af
IB
98 $(MAKE) ssh-eldiron SSH_ARGS="nix-store --gc"
99 $(MAKE) ssh-dilion SSH_ARGS="nix-store --gc"
100 $(MAKE) ssh-backup-2 SSH_ARGS="nix-store --gc"
101 $(MAKE) ssh-monitoring-1 SSH_ARGS="nix-store --gc"
4506dbe5 102.PHONY: cleanup