diff options
Diffstat (limited to 'hosts/surtr/tls.nix')
-rw-r--r-- | hosts/surtr/tls.nix | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/hosts/surtr/tls.nix b/hosts/surtr/tls.nix new file mode 100644 index 00000000..9581dd60 --- /dev/null +++ b/hosts/surtr/tls.nix | |||
@@ -0,0 +1,70 @@ | |||
1 | { config, pkgs, ... }: | ||
2 | let | ||
3 | knotCfg = config.services.knot; | ||
4 | |||
5 | knotDNSCredentials = zone: pkgs.writeText "lego-credentials" '' | ||
6 | EXEC_PATH=${knotDNSExec zone}/bin/update-dns.sh | ||
7 | EXEC_PROPAGATION_TIMEOUT=300 | ||
8 | EXEC_POLLING_INTERVAL=5 | ||
9 | ''; | ||
10 | knotDNSExec = zone: pkgs.writeScriptBin "update-dns.sh" '' | ||
11 | #!${pkgs.zsh}/bin/zsh -xe | ||
12 | |||
13 | mode=$1 | ||
14 | fqdn=$2 | ||
15 | challenge=$3 | ||
16 | |||
17 | owner=''${fqdn%".${zone}."} | ||
18 | |||
19 | commited= | ||
20 | function abort() { | ||
21 | [[ -n "''${commited}" ]] || ${knotCfg.cliWrappers}/bin/knotc zone-abort "${zone}" | ||
22 | } | ||
23 | |||
24 | ${knotCfg.cliWrappers}/bin/knotc zone-begin "${zone}" | ||
25 | trap abort EXIT | ||
26 | |||
27 | case "''${mode}" in | ||
28 | present) | ||
29 | ${knotCfg.cliWrappers}/bin/knotc zone-unset ${zone} "''${owner}" TXT '""' | ||
30 | ${knotCfg.cliWrappers}/bin/knotc zone-set ${zone} "''${owner}" 30 TXT "''${challenge}" | ||
31 | ;; | ||
32 | cleanup) | ||
33 | ${knotCfg.cliWrappers}/bin/knotc zone-unset ${zone} "''${owner}" TXT "''${challenge}" | ||
34 | ${knotCfg.cliWrappers}/bin/knotc zone-set ${zone} "''${owner}" 30 TXT '""' | ||
35 | ;; | ||
36 | *) | ||
37 | exit 2 | ||
38 | ;; | ||
39 | esac | ||
40 | |||
41 | ${knotCfg.cliWrappers}/bin/knotc zone-commit "${zone}" | ||
42 | commited=yes | ||
43 | ''; | ||
44 | in { | ||
45 | config = { | ||
46 | fileSystems."/var/lib/acme" = | ||
47 | { device = "surtr/safe/var-lib-acme"; | ||
48 | fsType = "zfs"; | ||
49 | }; | ||
50 | |||
51 | security.acme = { | ||
52 | server = "https://acme-staging-v02.api.letsencrypt.org/directory"; | ||
53 | |||
54 | acceptTerms = true; | ||
55 | preliminarySelfsigned = false; | ||
56 | email = "phikeebaogobaegh@141.li"; | ||
57 | certs = { | ||
58 | "rheperire.org" = { | ||
59 | domain = "rheperire.org"; | ||
60 | extraDomainNames = [ "*.rheperire.org" ]; | ||
61 | dnsProvider = "exec"; | ||
62 | credentialsFile = knotDNSCredentials "rheperire.org"; | ||
63 | dnsResolver = "1.1.1.1:53"; | ||
64 | }; | ||
65 | }; | ||
66 | }; | ||
67 | |||
68 | users.groups."knot".members = [ "acme" ]; | ||
69 | }; | ||
70 | } | ||