Merge #33614: nixos/kresd improvements
The PR was extended with other fixes. All tested by me atop 17.09.
This commit is contained in:
commit
d6bf8eb71b
@ -72,6 +72,7 @@ in
|
|||||||
(iface: if elem ":" (stringToCharacters iface) then "[${iface}]:53" else "${iface}:53")
|
(iface: if elem ":" (stringToCharacters iface) then "[${iface}]:53" else "${iface}:53")
|
||||||
cfg.interfaces;
|
cfg.interfaces;
|
||||||
socketConfig.ListenDatagram = listenStreams;
|
socketConfig.ListenDatagram = listenStreams;
|
||||||
|
socketConfig.FreeBind = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
systemd.sockets.kresd-control = rec {
|
systemd.sockets.kresd-control = rec {
|
||||||
@ -82,20 +83,11 @@ in
|
|||||||
socketConfig = {
|
socketConfig = {
|
||||||
FileDescriptorName = "control";
|
FileDescriptorName = "control";
|
||||||
Service = "kresd.service";
|
Service = "kresd.service";
|
||||||
SocketMode = "0660"; # only root user/group may connect
|
SocketMode = "0660"; # only root user/group may connect and control kresd
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Create the cacheDir; tmpfiles don't work on nixos-rebuild switch.
|
systemd.tmpfiles.rules = [ "d '${cfg.cacheDir}' 0770 kresd kresd - -" ];
|
||||||
systemd.services.kresd-cachedir = {
|
|
||||||
serviceConfig.Type = "oneshot";
|
|
||||||
script = ''
|
|
||||||
if [ ! -d '${cfg.cacheDir}' ]; then
|
|
||||||
mkdir -p '${cfg.cacheDir}'
|
|
||||||
chown kresd:kresd '${cfg.cacheDir}'
|
|
||||||
fi
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
systemd.services.kresd = {
|
systemd.services.kresd = {
|
||||||
description = "Knot-resolver daemon";
|
description = "Knot-resolver daemon";
|
||||||
@ -104,16 +96,15 @@ in
|
|||||||
User = "kresd";
|
User = "kresd";
|
||||||
Type = "notify";
|
Type = "notify";
|
||||||
WorkingDirectory = cfg.cacheDir;
|
WorkingDirectory = cfg.cacheDir;
|
||||||
|
Restart = "on-failure";
|
||||||
};
|
};
|
||||||
|
|
||||||
script = ''
|
script = ''
|
||||||
exec '${package}/bin/kresd' --config '${configFile}' \
|
exec '${package}/bin/kresd' --config '${configFile}' \
|
||||||
-k '${cfg.cacheDir}/root.key'
|
-k '${pkgs.dns-root-data}/root.key'
|
||||||
'';
|
'';
|
||||||
|
|
||||||
after = [ "kresd-cachedir.service" ];
|
requires = [ "kresd.socket" ];
|
||||||
requires = [ "kresd.socket" "kresd-cachedir.service" ];
|
|
||||||
wantedBy = [ "sockets.target" ];
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user