summaryrefslogtreecommitdiff
path: root/app-crypt/certbot
diff options
context:
space:
mode:
Diffstat (limited to 'app-crypt/certbot')
-rw-r--r--app-crypt/certbot/Manifest1
-rw-r--r--app-crypt/certbot/certbot-5.2.1.ebuild221
2 files changed, 222 insertions, 0 deletions
diff --git a/app-crypt/certbot/Manifest b/app-crypt/certbot/Manifest
index aa2dcbd68532..96c40c8f60e4 100644
--- a/app-crypt/certbot/Manifest
+++ b/app-crypt/certbot/Manifest
@@ -3,3 +3,4 @@ DIST certbot-4.1.1.gh.tar.gz 2325999 BLAKE2B 9bc3f3c3ce84c1a9846274901565db26745
DIST certbot-4.2.0.gh.tar.gz 2329899 BLAKE2B 443efb97693f8a455f4776d8bcafb80e007fd627cf8fe51b38c041e7f7709eb7b44a85710a57560c64c732aeebcb2e9e369bb2dba3ff41a9f421ecfd1d703211 SHA512 9003a2fe06dd05c7fde5954051feb8d11586acfeb5b2aab298d4eccae7cfd0a13366212eb812e2be118711d8c273f39bfb53d8590f9bab418338e46b1f628504
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
diff --git a/app-crypt/certbot/certbot-5.2.1.ebuild b/app-crypt/certbot/certbot-5.2.1.ebuild
new file mode 100644
index 000000000000..6e969274d148
--- /dev/null
+++ b/app-crypt/certbot/certbot-5.2.1.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
+}