summaryrefslogtreecommitdiff
path: root/hosts/surtr/tls.nix
blob: d087c9f5cbf8f0acc80e481f4faf047a0e3caf38 (plain)
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
{ config, pkgs, ... }:
let
  knotCfg = config.services.knot;
  
  knotDNSCredentials = zone: pkgs.writeText "lego-credentials" ''
    EXEC_PATH=${knotDNSExec zone}/bin/update-dns.sh
    EXEC_PROPAGATION_TIMEOUT=60
    EXEC_POLLING_INTERVAL=5
  '';
  knotDNSExec = zone: pkgs.writeScriptBin "update-dns.sh" ''
    #!${pkgs.zsh}/bin/zsh -xe

    mode=$1
    fqdn=$2
    challenge=$3

    owner=''${fqdn%".${zone}."}

    ${knotCfg.cliWrappers}/bin/knotc zone-begin "${zone}"

    case "''${mode}" in
      present)
        ${knotCfg.cliWrappers}/bin/knotc zone-set ${zone} "''${owner}" 30 TXT "''${challenge}"
        ;;
      cleanup)
        ${knotCfg.cliWrappers}/bin/knotc zone-unset ${zone} "''${owner}" TXT "''${challenge}"
        ;;
      *)
        exit 2
        ;;
    esac

    ${knotCfg.cliWrappers}/bin/knotc zone-commit "${zone}"
  '';
in {
  config = {
    fileSystems."/var/lib/acme" =
      { device = "surtr/safe/var-lib-acme";
        fsType = "zfs";
      };

    security.acme = {
      server = "https://acme-staging-v02.api.letsencrypt.org/directory";
      
      acceptTerms = true;
      preliminarySelfsigned = false;
      email = "phikeebaogobaegh@141.li";
      certs = {
        "rheperire.org" = {
          domain = "rheperire.org";
          extraDomainNames = [ "*.rheperire.org" ];
          dnsProvider = "exec";
          credentialsFile = knotDNSCredentials "rheperire.org";
          dnsResolver = "1.1.1.1:53";
        };
      };
    };

    users.groups."knot".members = [ "acme" ];
  };
}