Files
nixpkgs/pkgs/servers/dns/nsd/default.nix
2025-11-14 17:51:07 -08:00

91 lines
2.1 KiB
Nix

{
lib,
stdenv,
fetchurl,
libevent,
openssl,
pkg-config,
systemdMinimal,
nixosTests,
bind8Stats ? false,
checking ? false,
ipv6 ? true,
mmap ? false,
minimalResponses ? true,
nsec3 ? true,
ratelimit ? false,
recvmmsg ? false,
rootServer ? false,
rrtypes ? false,
zoneStats ? false,
withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal,
configFile ? "/etc/nsd/nsd.conf",
}:
stdenv.mkDerivation rec {
pname = "nsd";
version = "4.12.0";
src = fetchurl {
url = "https://www.nlnetlabs.nl/downloads/${pname}/${pname}-${version}.tar.gz";
sha256 = "sha256-+ezCz3m6UFgPLfYpGO/EQAhMW/EQV9tEwZqpZDzUteg=";
};
prePatch = ''
substituteInPlace nsd-control-setup.sh.in --replace openssl ${openssl}/bin/openssl
'';
nativeBuildInputs = lib.optionals withSystemd [
pkg-config
];
buildInputs = [
libevent
openssl
]
++ lib.optionals withSystemd [
systemdMinimal
];
enableParallelBuilding = true;
configureFlags =
let
edf = c: o: if c then [ "--enable-${o}" ] else [ "--disable-${o}" ];
in
edf bind8Stats "bind8-stats"
++ edf checking "checking"
++ edf ipv6 "ipv6"
++ edf mmap "mmap"
++ edf minimalResponses "minimal-responses"
++ edf nsec3 "nsec3"
++ edf ratelimit "ratelimit"
++ edf recvmmsg "recvmmsg"
++ edf rootServer "root-server"
++ edf rrtypes "draft-rrtypes"
++ edf zoneStats "zone-stats"
++ edf withSystemd "systemd"
++ [
"--with-ssl=${openssl.dev}"
"--with-libevent=${libevent.dev}"
"--with-nsd_conf_file=${configFile}"
"--with-configdir=etc/nsd"
];
patchPhase = ''
sed 's@$(INSTALL_DATA) nsd.conf.sample $(DESTDIR)$(nsdconfigfile).sample@@g' -i Makefile.in
'';
passthru.tests = {
inherit (nixosTests) nsd;
};
meta = with lib; {
homepage = "https://www.nlnetlabs.nl";
description = "Authoritative only, high performance, simple and open source name server";
license = licenses.bsd3;
platforms = platforms.unix;
maintainers = [ maintainers.hrdinka ];
};
}