nixpkgs/pkgs/tools/admin/letsencrypt/default.nix

51 lines
1.3 KiB
Nix
Raw Normal View History

{ stdenv, pythonPackages, fetchFromGitHub, dialog }:
2015-10-31 22:01:20 +01:00
pythonPackages.buildPythonApplication rec {
name = "letsencrypt-${version}";
version = "0.5.0";
src = fetchFromGitHub {
owner = "certbot";
repo = "certbot";
rev = "v${version}";
sha256 = "0x098cdyfgqvh7x5d3sz56qjpjyg5b4fl82086sm43d8mbz0h5rm";
2015-10-31 22:01:20 +01:00
};
propagatedBuildInputs = with pythonPackages; [
ConfigArgParse
acme
configobj
cryptography
parsedatetime
psutil
pyRFC3339
pyopenssl
python2-pythondialog
pytz
six
zope_component
zope_interface
2015-10-31 22:01:20 +01:00
];
buildInputs = [ dialog ] ++ (with pythonPackages; [ nose mock gnureadline ]);
2015-10-31 22:01:20 +01:00
patchPhase = ''
substituteInPlace letsencrypt/notify.py --replace "/usr/sbin/sendmail" "/var/setuid-wrappers/sendmail"
substituteInPlace letsencrypt/le_util.py --replace "sw_vers" "/usr/bin/sw_vers"
2015-10-31 22:01:20 +01:00
'';
postInstall = ''
for i in $out/bin/*; do
wrapProgram "$i" --prefix PYTHONPATH : "$PYTHONPATH" \
--prefix PATH : "${dialog}/bin:$PATH"
done
'';
meta = with stdenv.lib; {
homepage = src.meta.homepage;
2015-10-31 22:01:20 +01:00
description = "ACME client that can obtain certs and extensibly update server configurations";
platforms = platforms.unix;
maintainers = [ maintainers.iElectric ];
2015-10-31 22:05:12 +01:00
license = licenses.asl20;
2015-10-31 22:01:20 +01:00
};
}