commit: b56dec30c4e80216bc67efa393da6cbc5c82b7b1 Author: Thibaud CANALE <thican <AT> thican <DOT> net> AuthorDate: Wed Dec 10 23:30:22 2025 +0000 Commit: Matthew Thode <prometheanfire <AT> gentoo <DOT> org> CommitDate: Thu Dec 11 04:09:18 2025 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b56dec30
app-crypt/certbot: add 5.2.2 Signed-off-by: Thibaud CANALE <thican <AT> thican.net> Part-of: https://github.com/gentoo/gentoo/pull/44985 Signed-off-by: Matthew Thode <prometheanfire <AT> gentoo.org> app-crypt/certbot/Manifest | 1 + app-crypt/certbot/certbot-5.2.2.ebuild | 221 +++++++++++++++++++++++++++++++++ 2 files changed, 222 insertions(+) diff --git a/app-crypt/certbot/Manifest b/app-crypt/certbot/Manifest index 96c40c8f60e4..43151b844588 100644 --- a/app-crypt/certbot/Manifest +++ b/app-crypt/certbot/Manifest @@ -4,3 +4,4 @@ DIST certbot-4.2.0.gh.tar.gz 2329899 BLAKE2B 443efb97693f8a455f4776d8bcafb80e007 DIST certbot-5.0.0.gh.tar.gz 2317173 BLAKE2B 3b7bd0cf9493d3c57f8228fddc5e78a63ff90be90bfbbba3b91a0320f3e6ab8ab4ac1ddc3a9168dcaec6ea73bbf814397218a572fb92de24f7c2c53aed354a52 SHA512 13bdef8e678aa75b746c2ba685e3dd9b6d2f10641b631592a994e68483accb7c93467535d1dc7df79be2e7eac1dbf8917980192d729d639ab5f151eb731bca7d DIST certbot-5.1.0.gh.tar.gz 2319656 BLAKE2B b145f99e4b1c3ab3cab1ec66bcac073748703d1beacb40f5bc138603f29c960a9f73a27f29752fef74e45a2da5f320a03a8eb90b3b7d5183e62fad4b9ddf7d4b SHA512 5a4830b3e433acf5f21f93704f729f632c5e03c51ef0deab4f4928c0ee8004d51132a3504148fc8a706b810b55e572423457d9995c8164369c4678123eb10a3e DIST certbot-5.2.1.gh.tar.gz 2329137 BLAKE2B 3b764dbcb61167253ab1bc59f314c996e684390f3f37ecbc7c626b6ec59a29479d322355f6901150ec73b4357f406003d9b7eff298a5a8a8fa74c82360613456 SHA512 9477f6fa57f77da6fb3e8bee727535803d9ebfca0c921b80e9b01ccdcf4174282947e1738acd63f8d5b6b65425f945c3021eb58c9811950b6c362ce76f0d7144 +DIST certbot-5.2.2.gh.tar.gz 2327742 BLAKE2B 958e72f2f4265b45ca1faf1930f8aeb25ed8f255cb9d628d8e0120da6ff5df25857b1a32881cace57112fca674439b4e3b8cd2f19ef078a35c6aeb6b8382f4e9 SHA512 3a6d564a7e8f47fd59564c32eb3ac13f3724eb3edb5f1abfd0069cfb5393c68e1eb05a42afe6380b4b8e70ca4084acccdad1a342c79d17717ab40d42a1ada7e4 diff --git a/app-crypt/certbot/certbot-5.2.2.ebuild b/app-crypt/certbot/certbot-5.2.2.ebuild new file mode 100644 index 000000000000..6e969274d148 --- /dev/null +++ b/app-crypt/certbot/certbot-5.2.2.ebuild @@ -0,0 +1,221 @@ +# Copyright 1999-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +DISTUTILS_USE_PEP517=setuptools +PYTHON_COMPAT=( python3_{10..14} ) + +inherit distutils-r1 toolchain-funcs + +if [[ "${PV}" == *9999 ]]; then + inherit git-r3 + + EGIT_REPO_URI="https://github.com/certbot/certbot.git" + EGIT_SUBMODULES=() + EGIT_CHECKOUT_DIR="${WORKDIR}/${P}" +else + SRC_URI=" + https://github.com/certbot/certbot/archive/v${PV}.tar.gz + -> ${P}.gh.tar.gz + " + KEYWORDS="~amd64 ~arm ~arm64 ~ppc64 ~riscv ~x86" +fi + +DESCRIPTION="Let's Encrypt client to automate deployment of X.509 certificates" +HOMEPAGE=" + https://github.com/certbot/certbot + https://pypi.org/project/certbot/ + https://letsencrypt.org/ +" + +LICENSE="Apache-2.0" +SLOT="0" + +# acme required for certbot, and then required for modules +CERTBOT_BASE=(acme certbot) +# List of "subpackages" from tools/_release.sh (without acme which is already above) +CERTBOT_MODULES_EXTRA=( + apache + #dns-cloudflare # Requires missing packages, already in GURU + #dns-digitalocean # Requires missing packages, already in GURU + dns-dnsimple + dns-dnsmadeeasy + dns-gehirn + dns-google + dns-linode + dns-luadns + dns-nsone + dns-ovh + dns-rfc2136 + dns-route53 + dns-sakuracloud + nginx +) + +IUSE="selinux" +for module in "${CERTBOT_MODULES_EXTRA[@]}"; do + IUSE+=" certbot-${module}" +done + +BDEPEND=" + test? ( + dev-python/pytest[${PYTHON_USEDEP}] + dev-python/typing-extensions[${PYTHON_USEDEP}] + ) +" + +# See each setup.py for dependencies +# Also discard the previous related packages +# except their transition step +RDEPEND=" + >=dev-python/configargparse-1.5.3[${PYTHON_USEDEP}] + >=dev-python/configobj-5.0.6[${PYTHON_USEDEP}] + >=dev-python/cryptography-43.0.0[${PYTHON_USEDEP}] + >=dev-python/distro-1.0.1[${PYTHON_USEDEP}] + >=dev-python/josepy-2.0.0[${PYTHON_USEDEP}] + >=dev-python/parsedatetime-2.6[${PYTHON_USEDEP}] + >=dev-python/pyopenssl-25.0.0[${PYTHON_USEDEP}] + dev-python/pyrfc3339[${PYTHON_USEDEP}] + >=dev-python/requests-2.20.0[${PYTHON_USEDEP}] + certbot-apache? ( + dev-python/python-augeas[${PYTHON_USEDEP}] + ) + certbot-dns-dnsimple? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-dns-dnsmadeeasy? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-dns-gehirn? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-dns-google? ( + >=dev-python/google-api-python-client-1.6.5[${PYTHON_USEDEP}] + >=dev-python/google-auth-2.16.0[${PYTHON_USEDEP}] + ) + certbot-dns-linode? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-dns-luadns? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-dns-nsone? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-dns-ovh? ( + >=dev-python/dns-lexicon-3.15.1[${PYTHON_USEDEP}] + ) + certbot-dns-rfc2136? ( + >=dev-python/dnspython-2.6.1[${PYTHON_USEDEP}] + ) + certbot-dns-route53? ( + >=dev-python/boto3-1.15.15[${PYTHON_USEDEP}] + ) + certbot-dns-sakuracloud? ( + >=dev-python/dns-lexicon-3.14.1[${PYTHON_USEDEP}] + ) + certbot-nginx? ( + >=dev-python/pyopenssl-25.0.0[${PYTHON_USEDEP}] + >=dev-python/pyparsing-2.4.7[${PYTHON_USEDEP}] + ) + selinux? ( sec-policy/selinux-certbot ) +" +# RDEPEND+=" +# !<app-crypt/certbot-dns-cloudflare-3.2.0-r100 +# +# >=dev-python/requests-toolbelt-0.3.0[${PYTHON_USEDEP}] # @TODO is still necessary? +# certbot-dns-cloudflare? ( +# # Available in GURU +# >=dev-python/cloudflare-2.19[${PYTHON_USEDEP}] +# <dev-python/cloudflare-2.20[${PYTHON_USEDEP}] +# ) +# certbot-dns-digitalocean? ( +# # Available in GURU +# >=dev-python/digitalocean-1.15.0[${PYTHON_USEDEP}] +# ) +# " + +# Note: "docs" is not an actual directory under "S", they are actually +# under each modules, see python_compile_all redefinition, but keep +# this instruction enabled for dependency configuration. +distutils_enable_sphinx docs \ + dev-python/sphinx-rtd-theme +distutils_enable_tests pytest + +CERTBOT_DIRS=() +# Stores temporary modules docs in each subdirectories, +# will be used for HTML_DOCS +CERTBOT_DOCS="${T}/docs" + +src_prepare() { + default + + # set CERTBOT_DIRS + local base module + for base in "${CERTBOT_BASE[@]}"; do + CERTBOT_DIRS+=("${base}") + done + for module in "${CERTBOT_MODULES_EXTRA[@]}"; do + use "certbot-${module}" && + CERTBOT_DIRS+=("certbot-${module}") + done + + # Used to build documentation + mkdir "${CERTBOT_DOCS}" || die + + # Remove "broken" symbolic link used as documentation. + # Copy actual file, removing source breaks wheel building. + rm -f "${S}/README.rst" + cp "${S}/certbot/README.rst" "${S}/README.rst" || die +} + +python_compile() { + local dir + for dir in "${CERTBOT_DIRS[@]}"; do + pushd "${dir}" > /dev/null || die + + distutils-r1_python_compile + + popd > /dev/null || die + done +} + +# Used to build documentation +python_compile_all() { + use doc || return + + local dir + for dir in "${CERTBOT_DIRS[@]}"; do + # There is no documentation in certbot-apache or certbot-nginx. + if has "${dir}" "certbot-apache" "certbot-nginx"; then + continue + fi + + pushd "${dir}" > /dev/null || die + + sphinx_compile_all + + # Note: discard the `/.` in last entry suffix to avoid error + # with `mv` command. + mv "${HTML_DOCS[-1]%/.}" "${CERTBOT_DOCS}/${dir}" || die + + popd > /dev/null || die + done + + # And finally give the result. + # Note: the suffix `/.` here is to discard the holding directory. + HTML_DOCS=( "${CERTBOT_DOCS}/." ) +} + +python_test() { + local -x PYTEST_DISABLE_PLUGIN_AUTOLOAD=1 + + tc-has-64bit-time_t || EPYTEST_DESELECT+=( + 'certbot/_internal/tests/storage_test.py::RenewableCertTests::test_time_interval_judgments' + ) + + # Change for pytest rootdir is required. + cd "${BUILD_DIR}/install$(python_get_sitedir)" || die + epytest +}
