nixpkgs/pkgs/servers/dns/nsd/default.nix

62 lines
1.8 KiB
Nix
Raw Normal View History

2014-06-12 11:14:44 +02:00
{ config, stdenv, fetchurl, libevent, openssl
, bind8Stats ? false
, checking ? false
, ipv6 ? true
, mmap ? false
, minimalResponses ? true
, nsec3 ? true
, ratelimit ? false
, recvmmsg ? false
, rootServer ? false
2015-03-19 12:10:55 +01:00
, rrtypes ? false
2015-03-18 21:01:35 +01:00
, zoneStats ? false
, configFile ? "etc/nsd/nsd.conf"
2014-06-12 11:14:44 +02:00
}:
stdenv.mkDerivation rec {
name = "nsd-4.1.20";
2014-06-12 11:14:44 +02:00
src = fetchurl {
url = "http://www.nlnetlabs.nl/downloads/nsd/${name}.tar.gz";
sha256 = "04zph9zli3a0zx1sfphwbxx6f8whdxcjai6w0k7a565vgcfzd5wa";
2014-06-12 11:14:44 +02:00
};
prePatch = ''
substituteInPlace nsd-control-setup.sh.in --replace openssl ${openssl}/bin/openssl
'';
2014-06-12 11:14:44 +02:00
buildInputs = [ libevent openssl ];
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"
2015-03-19 12:10:55 +01:00
++ edf rrtypes "draft-rrtypes"
2015-03-18 21:01:35 +01:00
++ edf zoneStats "zone-stats"
++ [ "--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
'';
2014-06-12 11:14:44 +02:00
meta = with stdenv.lib; {
2014-06-12 11:14:44 +02:00
homepage = http://www.nlnetlabs.nl;
description = "Authoritative only, high performance, simple and open source name server";
license = licenses.bsd3;
platforms = platforms.unix;
maintainers = [ maintainers.hrdinka ];
2014-06-12 11:14:44 +02:00
};
}