From a9711244642c0224a392176dc55db0df8a11b864 Mon Sep 17 00:00:00 2001 From: ibizaman Date: Thu, 14 Sep 2023 22:21:15 -0700 Subject: [PATCH] make ssl module more generic --- modules/ssl.nix | 37 +++++++++++++++++++++++++------------ 1 file changed, 25 insertions(+), 12 deletions(-) diff --git a/modules/ssl.nix b/modules/ssl.nix index 23ee793..a4d6c1e 100644 --- a/modules/ssl.nix +++ b/modules/ssl.nix @@ -9,7 +9,16 @@ in sopsFile = lib.mkOption { type = lib.types.path; - description = "Sops file location"; + description = ''Sops file location. + + To use Linode to prove the dns challenge, the content of the file should be the following, + with XXX replaced by your Linode API token. + + LINODE_HTTP_TIMEOUT=10 + LINODE_POLLING_INTERVAL=10 + LINODE_PROPAGATION_TIMEOUT=240 + LINODE_TOKEN=XXX + ''; example = "secrets/haproxy.yaml"; }; @@ -19,6 +28,18 @@ in example = "domain.com"; }; + dnsProvider = lib.mkOption { + description = lib.mdDoc "DNS provider."; + type = lib.types.str; + example = "linode"; + }; + + dnsResolver = lib.mkOption { + description = lib.mdDoc "IP of a DNS server used to resolve hostnames."; + type = lib.types.str; + default = "8.8.8.8"; + }; + adminEmail = lib.mkOption { description = lib.mdDoc "Admin email in case certificate retrieval goes wrong."; type = lib.types.str; @@ -40,20 +61,12 @@ in }; defaults = { email = cfg.adminEmail; - dnsProvider = "linode"; - dnsResolver = "8.8.8.8"; - # For example, to use Linode to prove the dns challenge, - # the content of the file should be the following, with - # XXX replaced by your Linode API token. - # LINODE_HTTP_TIMEOUT=10 - # LINODE_POLLING_INTERVAL=10 - # LINODE_PROPAGATION_TIMEOUT=240 - # LINODE_TOKEN=XXX - credentialsFile = "/run/secrets/linode"; + inherit (cfg) dnsProvider dnsResolver; + credentialsFile = "/run/secrets/acme"; enableDebugLogs = false; }; }; - sops.secrets.linode = { + sops.secrets.acme = { inherit (cfg) sopsFile; restartUnits = [ "acme-${cfg.domain}.service" ]; };