{ stdenv, fetchurl, nspr, perl, zlib, sqlite }: let nssPEM = fetchurl { url = http://dev.gentoo.org/~polynomial-c/mozilla/nss-3.15.4-pem-support-20140109.patch.xz; sha256 = "10ibz6y0hknac15zr6dw4gv9nb5r5z9ym6gq18j3xqx7v7n3vpdw"; }; in stdenv.mkDerivation rec { name = "nss-${version}"; version = "3.28.3"; src = fetchurl { url = "mirror://mozilla/security/nss/releases/NSS_3_28_3_RTM/src/${name}.tar.gz"; sha256 = "1wrx2ig6yvgywjs25hzy4szgml21hwhd7ds0ghyfybhkiq7lyg6x"; }; buildInputs = [ perl zlib sqlite ]; propagatedBuildInputs = [ nspr ]; prePatch = '' xz -d < ${nssPEM} | patch -p1 ''; patches = [ # Install a nss.pc (pkgconfig) file and nss-config script # Upstream issue: https://bugzilla.mozilla.org/show_bug.cgi?id=530672 (fetchurl { name = "nss-3.28-gentoo-fixups.patch"; url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/" + "dev-libs/nss/files/nss-3.28-gentoo-fixups.patch" + "?id=05c31f8cca591b3ce8219e4def7c26c7b1b130d6"; sha256 = "0z58axd1n7vq4kdp5mrb3dsg6di39a1g40s3shl6n2dzs14c1y2q"; }) # Based on http://patch-tracker.debian.org/patch/series/dl/nss/2:3.15.4-1/85_security_load.patch ./85_security_load.patch ]; patchFlags = "-p0"; postPatch = '' # Fix up the patch from Gentoo. sed -i \ -e "/^PREFIX =/s|= /usr|= $out|" \ -e '/@libdir@/s|gentoo/nss|lib|' \ -e '/ln -sf/d' \ nss/config/Makefile # Note for spacing/tab nazis: The TAB characters are intentional! cat >> nss/config/Makefile <