summary refs log tree commit diff
diff options
context:
space:
mode:
authorKirill Elagin <kirelagin@gmail.com>2017-06-17 22:05:07 +0300
committerKirill Elagin <kirelagin@gmail.com>2017-06-18 17:29:29 +0300
commit13d026e219c2f6c6f35f39abf5c911eca4884355 (patch)
treee2017852aefe71ac4c2d4a957d5f0953ffac59ae
parent9d4b23f245182f11770dbcc16587a16fda1d45a3 (diff)
downloadnixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.tar
nixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.tar.gz
nixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.tar.bz2
nixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.tar.lz
nixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.tar.xz
nixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.tar.zst
nixpkgs-13d026e219c2f6c6f35f39abf5c911eca4884355.zip
bind: Use rndc to control the daemon
-rw-r--r--nixos/modules/services/networking/bind.nix17
1 files changed, 16 insertions, 1 deletions
diff --git a/nixos/modules/services/networking/bind.nix b/nixos/modules/services/networking/bind.nix
index 0272b6ceff2..e6d9e67116b 100644
--- a/nixos/modules/services/networking/bind.nix
+++ b/nixos/modules/services/networking/bind.nix
@@ -10,6 +10,11 @@ let
 
   confFile = pkgs.writeText "named.conf"
     ''
+      include "/etc/bind/rndc.key";
+      controls {
+        inet 127.0.0.1 allow {localhost;} keys {"rndc-key";};
+      };
+
       acl cachenetworks { ${concatMapStrings (entry: " ${entry}; ") cfg.cacheNetworks} };
       acl badnetworks { ${concatMapStrings (entry: " ${entry}; ") cfg.blockedNetworks} };
 
@@ -151,11 +156,21 @@ in
       wantedBy = [ "multi-user.target" ];
 
       preStart = ''
+        mkdir -m 0755 -p /etc/bind
+        if ! [ -f "/etc/bind/rndc.key" ]; then
+          ${pkgs.bind.out}/sbin/rndc-confgen -r /dev/urandom -c /etc/bind/rndc.key -u ${bindUser} -a -A hmac-sha256 2>/dev/null
+        fi
+
         ${pkgs.coreutils}/bin/mkdir -p /var/run/named
         chown ${bindUser} /var/run/named
       '';
 
-      script = "${pkgs.bind.out}/sbin/named -u ${bindUser} ${optionalString cfg.ipv4Only "-4"} -c ${cfg.configFile} -f";
+      serviceConfig = {
+        ExecStart  = "${pkgs.bind.out}/sbin/named -u ${bindUser} ${optionalString cfg.ipv4Only "-4"} -c ${cfg.configFile} -f";
+        ExecReload = "${pkgs.bind.out}/sbin/rndc -k '/etc/bind/rndc.key' reload";
+        ExecStop   = "${pkgs.bind.out}/sbin/rndc -k '/etc/bind/rndc.key' stop";
+      };
+
       unitConfig.Documentation = "man:named(8)";
     };
   };