106 lines
2.3 KiB
Nix
106 lines
2.3 KiB
Nix
|
{
|
||
|
lib,
|
||
|
buildPythonPackage,
|
||
|
python,
|
||
|
runCommand,
|
||
|
fetchFromGitHub,
|
||
|
fetchpatch,
|
||
|
configargparse,
|
||
|
acme,
|
||
|
configobj,
|
||
|
cryptography,
|
||
|
distro,
|
||
|
josepy,
|
||
|
parsedatetime,
|
||
|
pyrfc3339,
|
||
|
pytz,
|
||
|
setuptools,
|
||
|
dialog,
|
||
|
gnureadline,
|
||
|
pytest-xdist,
|
||
|
pytestCheckHook,
|
||
|
python-dateutil,
|
||
|
}:
|
||
|
|
||
|
buildPythonPackage rec {
|
||
|
pname = "certbot";
|
||
|
version = "2.11.0";
|
||
|
pyproject = true;
|
||
|
|
||
|
src = fetchFromGitHub {
|
||
|
owner = "certbot";
|
||
|
repo = "certbot";
|
||
|
rev = "refs/tags/v${version}";
|
||
|
hash = "sha256-Qee7lUjgliG5fmUWWPm3MzpGJHUF/DXZ08UA6kkWjjk=";
|
||
|
};
|
||
|
|
||
|
patches = [
|
||
|
(fetchpatch {
|
||
|
name = "CSR_support_in_pyOpenSSL_is_deprecated.patch";
|
||
|
url = "https://github.com/certbot/certbot/commit/f005045d87b25f1922774685646e57765aa202ad.patch";
|
||
|
includes = [ "pytest.ini" ];
|
||
|
hash = "sha256-YcQbZb7DLU+AXxNyqJRYZIC18DuT6X8kGbfdYtUrHiA=";
|
||
|
})
|
||
|
];
|
||
|
|
||
|
postPatch = "cd ${pname}"; # using sourceRoot would interfere with patches
|
||
|
|
||
|
build-system = [ setuptools ];
|
||
|
|
||
|
dependencies = [
|
||
|
configargparse
|
||
|
acme
|
||
|
configobj
|
||
|
cryptography
|
||
|
distro
|
||
|
josepy
|
||
|
parsedatetime
|
||
|
pyrfc3339
|
||
|
pytz
|
||
|
setuptools # for pkg_resources
|
||
|
];
|
||
|
|
||
|
buildInputs = [
|
||
|
dialog
|
||
|
gnureadline
|
||
|
];
|
||
|
|
||
|
nativeCheckInputs = [
|
||
|
python-dateutil
|
||
|
pytestCheckHook
|
||
|
pytest-xdist
|
||
|
];
|
||
|
|
||
|
pytestFlagsArray = [
|
||
|
"-o cache_dir=$(mktemp -d)"
|
||
|
"-W"
|
||
|
"ignore::DeprecationWarning"
|
||
|
];
|
||
|
|
||
|
makeWrapperArgs = [ "--prefix PATH : ${dialog}/bin" ];
|
||
|
|
||
|
# certbot.withPlugins has a similar calling convention as python*.withPackages
|
||
|
# it gets invoked with a lambda, and invokes that lambda with the python package set matching certbot's:
|
||
|
# certbot.withPlugins (cp: [ cp.certbot-dns-foo ])
|
||
|
passthru.withPlugins =
|
||
|
f:
|
||
|
let
|
||
|
pythonEnv = python.withPackages f;
|
||
|
in
|
||
|
runCommand "certbot-with-plugins" { } ''
|
||
|
mkdir -p $out/bin
|
||
|
cd $out/bin
|
||
|
ln -s ${pythonEnv}/bin/certbot
|
||
|
'';
|
||
|
|
||
|
meta = with lib; {
|
||
|
homepage = "https://github.com/certbot/certbot";
|
||
|
changelog = "https://github.com/certbot/certbot/blob/${src.rev}/certbot/CHANGELOG.md";
|
||
|
description = "ACME client that can obtain certs and extensibly update server configurations";
|
||
|
platforms = platforms.unix;
|
||
|
mainProgram = "certbot";
|
||
|
maintainers = with maintainers; [ domenkozar ];
|
||
|
license = with licenses; [ asl20 ];
|
||
|
};
|
||
|
}
|