summaryrefslogtreecommitdiff
path: root/dev-python/authlib/authlib-1.6.6.ebuild
diff options
context:
space:
mode:
authorRepository mirror & CI <repomirrorci@gentoo.org>2025-12-13 08:00:48 +0000
committerRepository mirror & CI <repomirrorci@gentoo.org>2025-12-13 08:00:48 +0000
commitcfd0ef6d9e378f2680de2ced786633111aa43ee9 (patch)
treef39e624e782d98956a4b12833bcc18d21ea79083 /dev-python/authlib/authlib-1.6.6.ebuild
parent43132ab89408d466145b52fb6b3c73bf232839a2 (diff)
parent5fa4e5e4509b54060914e28a2777c190b53d3da4 (diff)
downloadgentoo-cfd0ef6d9e378f2680de2ced786633111aa43ee9.tar.gz
gentoo-cfd0ef6d9e378f2680de2ced786633111aa43ee9.tar.bz2
gentoo-cfd0ef6d9e378f2680de2ced786633111aa43ee9.zip
Merge updates from master
Diffstat (limited to 'dev-python/authlib/authlib-1.6.6.ebuild')
-rw-r--r--dev-python/authlib/authlib-1.6.6.ebuild74
1 files changed, 74 insertions, 0 deletions
diff --git a/dev-python/authlib/authlib-1.6.6.ebuild b/dev-python/authlib/authlib-1.6.6.ebuild
new file mode 100644
index 000000000000..625edf4230ee
--- /dev/null
+++ b/dev-python/authlib/authlib-1.6.6.ebuild
@@ -0,0 +1,74 @@
+# 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_{11..13} )
+
+inherit distutils-r1
+
+DESCRIPTION="A Python library in building OAuth and OpenID Connect servers and clients"
+HOMEPAGE="
+ https://authlib.org/
+ https://github.com/authlib/authlib/
+ https://pypi.org/project/Authlib/
+"
+# pypi source distribution excludes the tests
+SRC_URI="
+ https://github.com/authlib/authlib/archive/refs/tags/v${PV}.tar.gz
+ -> ${P}.gh.tar.gz
+"
+
+LICENSE="BSD"
+SLOT="0"
+KEYWORDS="~amd64"
+IUSE="django flask jose test"
+RESTRICT="!test? ( test )"
+
+RDEPEND="
+ dev-python/cryptography[${PYTHON_USEDEP}]
+ django? (
+ dev-python/django[${PYTHON_USEDEP}]
+ )
+ flask? (
+ dev-python/flask[${PYTHON_USEDEP}]
+ dev-python/flask-sqlalchemy[${PYTHON_USEDEP}]
+ )
+ jose? (
+ >=dev-python/pycryptodome-3.10[${PYTHON_USEDEP}]
+ )
+"
+BDEPEND="
+ test? (
+ dev-python/anyio[${PYTHON_USEDEP}]
+ dev-python/cachelib[${PYTHON_USEDEP}]
+ dev-python/django[${PYTHON_USEDEP}]
+ dev-python/flask[${PYTHON_USEDEP}]
+ dev-python/flask-sqlalchemy[${PYTHON_USEDEP}]
+ dev-python/httpx[${PYTHON_USEDEP}]
+ >=dev-python/pycryptodome-3.10[${PYTHON_USEDEP}]
+ dev-python/requests[${PYTHON_USEDEP}]
+ dev-python/starlette[${PYTHON_USEDEP}]
+ )
+"
+
+EPYTEST_PLUGINS=( pytest-asyncio )
+EPYTEST_XDIST=1
+distutils_enable_tests pytest
+
+src_prepare() {
+ distutils-r1_src_prepare
+
+ # convert from pycryptodomex to pycryptodome
+ sed -i -e 's:from Cryptodome:from Crypto:' \
+ authlib/jose/drafts/_jwe_enc_cryptodome.py || die
+}
+
+python_test() {
+ local -x DJANGO_SETTINGS_MODULE=tests.django_settings
+ epytest tests/{core,jose,clients,flask}
+
+ # TODO: django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet.
+ #epytest tests/django
+}