91 lines
2.1 KiB
Nix
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 ];
|
|
};
|
|
}
|