Merge pull request #17323 from arpa2/hashslinger
Hash-slinger: init at 2.7.0
This commit is contained in:
commit
8f9326ffd8
63
pkgs/tools/networking/unbound/python.nix
Normal file
63
pkgs/tools/networking/unbound/python.nix
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
{ stdenv, fetchurl, openssl, expat, libevent, swig, python, pythonPackages }:
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
pname = "pyunbound";
|
||||||
|
name = "${pname}-${version}";
|
||||||
|
version = "1.5.9";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "http://unbound.net/downloads/unbound-${version}.tar.gz";
|
||||||
|
sha256 = "01328cfac99ab5b8c47115151896a244979e442e284eb962c0ea84b7782b6990";
|
||||||
|
};
|
||||||
|
|
||||||
|
buildInputs = [ openssl expat libevent swig python ];
|
||||||
|
|
||||||
|
patchPhase = ''substituteInPlace Makefile.in \
|
||||||
|
--replace "\$(DESTDIR)\$(PYTHON_SITE_PKG)" "$out/${python.sitePackages}" \
|
||||||
|
--replace "\$(LIBTOOL) --mode=install cp _unbound.la" "cp _unbound.la"
|
||||||
|
'';
|
||||||
|
|
||||||
|
preConfigure = "export PYTHON_VERSION=${python.majorVersion}";
|
||||||
|
|
||||||
|
configureFlags = [
|
||||||
|
"--with-ssl=${openssl.dev}"
|
||||||
|
"--with-libexpat=${expat.dev}"
|
||||||
|
"--with-libevent=${libevent.dev}"
|
||||||
|
"--localstatedir=/var"
|
||||||
|
"--sysconfdir=/etc"
|
||||||
|
"--sbindir=\${out}/bin"
|
||||||
|
"--enable-pie"
|
||||||
|
"--enable-relro-now"
|
||||||
|
"--with-pyunbound"
|
||||||
|
"DESTDIR=$out PREFIX="
|
||||||
|
];
|
||||||
|
|
||||||
|
preInstall = ''
|
||||||
|
mkdir -p $out/${python.sitePackages} $out/etc/${pname}
|
||||||
|
cp .libs/_unbound.so .libs/libunbound.so* $out/${python.sitePackages}
|
||||||
|
substituteInPlace _unbound.la \
|
||||||
|
--replace "-L.libs $PWD/libunbound.la" "-L$out/${python.sitePackages}" \
|
||||||
|
--replace "libdir=\'$PWD/${python.sitePackages}\'" "libdir=\'$out/${python.sitePackages}\'"
|
||||||
|
'';
|
||||||
|
|
||||||
|
installFlags = [ "configfile=\${out}/etc/unbound/unbound.conf pyunbound-install lib" ];
|
||||||
|
|
||||||
|
# All we want is the Unbound Python module
|
||||||
|
postInstall = ''
|
||||||
|
# Generate the built in root anchor and root key and store these in a logical place
|
||||||
|
# to be used by tools depending only on the Python module
|
||||||
|
$out/bin/unbound-anchor -l | head -1 > $out/etc/${pname}/root.anchor
|
||||||
|
$out/bin/unbound-anchor -l | tail --lines=+2 - > $out/etc/${pname}/root.key
|
||||||
|
# We don't need anything else
|
||||||
|
rm -fR $out/bin $out/share $out/include $out/etc/unbound
|
||||||
|
patchelf --replace-needed libunbound.so.2 $out/${python.sitePackages}/libunbound.so.2 $out/${python.sitePackages}/_unbound.so
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with stdenv.lib; {
|
||||||
|
description = "Python library for Unbound, the validating, recursive, and caching DNS resolver";
|
||||||
|
license = licenses.bsd3;
|
||||||
|
homepage = http://www.unbound.net;
|
||||||
|
maintainers = with maintainers; [ leenaars ];
|
||||||
|
platforms = stdenv.lib.platforms.unix;
|
||||||
|
};
|
||||||
|
}
|
44
pkgs/tools/security/hash-slinger/default.nix
Normal file
44
pkgs/tools/security/hash-slinger/default.nix
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
{ stdenv, fetchFromGitHub, pythonPackages, openssh, gnupg, unbound, libreswan }:
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
pname = "hash-slinger";
|
||||||
|
name = "${pname}-${version}";
|
||||||
|
version = "2.7";
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "letoams";
|
||||||
|
repo = "${pname}";
|
||||||
|
rev = "${version}";
|
||||||
|
sha256 = "05wn744ydclpnpyah6yfjqlfjlasrrhzj48lqmm5a91nyps5yqyn";
|
||||||
|
};
|
||||||
|
|
||||||
|
pythonPath = with pythonPackages; [ dns m2crypto ipaddr python-gnupg
|
||||||
|
pyunbound ];
|
||||||
|
|
||||||
|
buildInputs = [ pythonPackages.wrapPython ];
|
||||||
|
propagatedBuildInputs = [ unbound libreswan ] ++ pythonPath;
|
||||||
|
propagatedUserEnvPkgs = [ unbound libreswan ];
|
||||||
|
|
||||||
|
patchPhase = ''
|
||||||
|
substituteInPlace Makefile \
|
||||||
|
--replace "$(DESTDIR)/usr" "$out"
|
||||||
|
substituteInPlace ipseckey \
|
||||||
|
--replace "/usr/sbin/ipsec" "${libreswan}/sbin/ipsec"
|
||||||
|
substituteInPlace tlsa \
|
||||||
|
--replace "/var/lib/unbound/root" "${pythonPackages.pyunbound}/etc/pyunbound/root"
|
||||||
|
patchShebangs *
|
||||||
|
'';
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p $out/bin $out/man $out/${python.sitePackages}/
|
||||||
|
make install
|
||||||
|
wrapPythonPrograms
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Various tools to generate special DNS records";
|
||||||
|
homepage = "https://github.com/letoams/hash-slinger";
|
||||||
|
license = stdenv.lib.licenses.gpl2Plus;
|
||||||
|
maintainers = [ stdenv.lib.maintainers.leenaars ];
|
||||||
|
};
|
||||||
|
}
|
@ -1964,6 +1964,8 @@ in
|
|||||||
|
|
||||||
hashcat = callPackage ../tools/security/hashcat { };
|
hashcat = callPackage ../tools/security/hashcat { };
|
||||||
|
|
||||||
|
hash-slinger = callPackage ../tools/security/hash-slinger { };
|
||||||
|
|
||||||
hal-flash = callPackage ../os-specific/linux/hal-flash { };
|
hal-flash = callPackage ../os-specific/linux/hal-flash { };
|
||||||
|
|
||||||
halibut = callPackage ../tools/typesetting/halibut { };
|
halibut = callPackage ../tools/typesetting/halibut { };
|
||||||
|
@ -327,6 +327,8 @@ in modules // {
|
|||||||
hdf5 = pkgs.hdf5.override { zlib = pkgs.zlib; };
|
hdf5 = pkgs.hdf5.override { zlib = pkgs.zlib; };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pyunbound = callPackage ../tools/networking/unbound/python.nix { };
|
||||||
|
|
||||||
# packages defined here
|
# packages defined here
|
||||||
|
|
||||||
aafigure = buildPythonPackage rec {
|
aafigure = buildPythonPackage rec {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user