diff options
author | Kirill Elagin <kirelagin@gmail.com> | 2017-06-17 22:05:07 +0300 |
---|---|---|
committer | Kirill Elagin <kirelagin@gmail.com> | 2017-06-18 17:29:29 +0300 |
commit | 13d026e219c2f6c6f35f39abf5c911eca4884355 (patch) | |
tree | e2017852aefe71ac4c2d4a957d5f0953ffac59ae | |
parent | 9d4b23f245182f11770dbcc16587a16fda1d45a3 (diff) | |
download | nixpkgs-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.nix | 17 |
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)"; }; }; |