ae2dc6aea6
GitOrigin-RevId: 4c2fcb090b1f3e5b47eaa7bd33913b574a11e0a0
101 lines
2.3 KiB
Nix
101 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
|
|
|
|
nativeBuildInputs = [ setuptools ];
|
|
|
|
propagatedBuildInputs = [
|
|
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)" ];
|
|
|
|
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 ];
|
|
};
|
|
}
|