1 { config, pkgs, lib, ... }:
6 cfg = config.services.skydns;
9 options.services.skydns = {
10 enable = mkEnableOption "skydns service";
14 default = [ "http://127.0.0.1:2379" ];
15 type = types.listOf types.str;
16 description = "Skydns list of etcd endpoints to connect to.";
21 type = types.nullOr types.path;
22 description = "Skydns path of TLS client certificate - private key.";
27 type = types.nullOr types.path;
28 description = "Skydns path of TLS client certificate - public key.";
33 type = types.nullOr types.path;
34 description = "Skydns path of TLS certificate authority public key.";
39 default = "0.0.0.0:53";
41 description = "Skydns address to bind to.";
45 default = "skydns.local.";
47 description = "Skydns default domain if not specified by etcd config.";
50 nameservers = mkOption {
51 default = map (n: n + ":53") config.networking.nameservers;
52 defaultText = literalExpression ''map (n: n + ":53") config.networking.nameservers'';
53 type = types.listOf types.str;
54 description = "Skydns list of nameservers to forward DNS requests to when not authoritative for a domain.";
55 example = ["8.8.8.8:53" "8.8.4.4:53"];
58 package = mkPackageOption pkgs "skydns" { };
60 extraConfig = mkOption {
62 type = types.attrsOf types.str;
63 description = "Skydns attribute set of extra config options passed as environment variables.";
67 config = mkIf (cfg.enable) {
68 systemd.services.skydns = {
69 wantedBy = [ "multi-user.target" ];
70 after = [ "network.target" "etcd.service" ];
71 description = "Skydns Service";
73 ETCD_MACHINES = concatStringsSep "," cfg.etcd.machines;
74 ETCD_TLSKEY = cfg.etcd.tlsKey;
75 ETCD_TLSPEM = cfg.etcd.tlsPem;
76 ETCD_CACERT = cfg.etcd.caCert;
77 SKYDNS_ADDR = cfg.address;
78 SKYDNS_DOMAIN = cfg.domain;
79 SKYDNS_NAMESERVERS = concatStringsSep "," cfg.nameservers;
82 ExecStart = "${cfg.package}/bin/skydns";
86 environment.systemPackages = [ cfg.package ];