django-auth-adfs 1.11.1__tar.gz → 1.11.5__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/PKG-INFO +11 -4
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/__init__.py +1 -1
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/config.py +9 -1
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/drf_urls.py +1 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/pyproject.toml +3 -2
- django-auth-adfs-1.11.1/setup.py +0 -38
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/LICENSE +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/README.rst +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/backend.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/drf-urls.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/exceptions.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/middleware.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/rest_framework.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/signals.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/templates/django_auth_adfs/login_failed.html +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/urls.py +0 -0
- {django-auth-adfs-1.11.1 → django_auth_adfs-1.11.5}/django_auth_adfs/views.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: django-auth-adfs
|
3
|
-
Version: 1.11.
|
3
|
+
Version: 1.11.5
|
4
4
|
Summary: A Django authentication backend for Microsoft ADFS and AzureAD
|
5
5
|
Home-page: https://github.com/snok/django-auth-adfs
|
6
6
|
License: BSD
|
@@ -22,7 +22,14 @@ Classifier: License :: Other/Proprietary License
|
|
22
22
|
Classifier: Operating System :: OS Independent
|
23
23
|
Classifier: Programming Language :: Python
|
24
24
|
Classifier: Programming Language :: Python :: 3
|
25
|
+
Classifier: Programming Language :: Python :: 3.7
|
26
|
+
Classifier: Programming Language :: Python :: 3.8
|
27
|
+
Classifier: Programming Language :: Python :: 3.9
|
28
|
+
Classifier: Programming Language :: Python :: 3.10
|
29
|
+
Classifier: Programming Language :: Python :: 3.11
|
30
|
+
Classifier: Programming Language :: Python :: 3
|
25
31
|
Classifier: Programming Language :: Python :: 3.10
|
32
|
+
Classifier: Programming Language :: Python :: 3.11
|
26
33
|
Classifier: Programming Language :: Python :: 3.7
|
27
34
|
Classifier: Programming Language :: Python :: 3.8
|
28
35
|
Classifier: Programming Language :: Python :: 3.9
|
@@ -32,9 +39,9 @@ Classifier: Topic :: Internet :: WWW/HTTP :: WSGI
|
|
32
39
|
Classifier: Topic :: Software Development :: Libraries :: Application Frameworks
|
33
40
|
Classifier: Topic :: Software Development :: Libraries :: Python Modules
|
34
41
|
Requires-Dist: PyJWT (>=2.4.0,<3.0.0)
|
35
|
-
Requires-Dist: cryptography (>=1.7,<
|
36
|
-
Requires-Dist: django (>=3,<4);
|
37
|
-
Requires-Dist: django (>=3,<5); python_version >= "3.8"
|
42
|
+
Requires-Dist: cryptography (>=1.7,<40.0)
|
43
|
+
Requires-Dist: django (>=3,<4) ; python_full_version <= "3.7.0"
|
44
|
+
Requires-Dist: django (>=3,<5) ; python_version >= "3.8"
|
38
45
|
Requires-Dist: requests (>=1,<3)
|
39
46
|
Requires-Dist: urllib3 (>=1.26.0,<2.0.0)
|
40
47
|
Project-URL: Documentation, https://django-auth-adfs.readthedocs.io/en/latest
|
@@ -78,6 +78,7 @@ class Settings(object):
|
|
78
78
|
self.PROXIES = None
|
79
79
|
|
80
80
|
self.VERSION = 'v1.0'
|
81
|
+
self.SCOPES = []
|
81
82
|
|
82
83
|
required_settings = [
|
83
84
|
"AUDIENCE",
|
@@ -138,6 +139,10 @@ class Settings(object):
|
|
138
139
|
elif "VERSION" in _settings:
|
139
140
|
raise ImproperlyConfigured("The VERSION cannot be set when TENANT_ID is not set.")
|
140
141
|
|
142
|
+
if self.VERSION == "v2.0" and not self.SCOPES and self.RELYING_PARTY_ID:
|
143
|
+
warnings.warn('Use `SCOPES` for AzureAD instead of RELYING_PARTY_ID', DeprecationWarning)
|
144
|
+
if not isinstance(self.SCOPES, list):
|
145
|
+
raise ImproperlyConfigured("Scopes must be a list")
|
141
146
|
# Overwrite defaults with user settings
|
142
147
|
for setting, value in _settings.items():
|
143
148
|
if hasattr(self, setting):
|
@@ -346,7 +351,10 @@ class ProviderConfig(object):
|
|
346
351
|
})
|
347
352
|
if self._mode == "openid_connect":
|
348
353
|
if settings.VERSION == 'v2.0':
|
349
|
-
|
354
|
+
if settings.SCOPES:
|
355
|
+
query['scope'] = " ".join(settings.SCOPES)
|
356
|
+
else:
|
357
|
+
query["scope"] = f"openid api://{settings.RELYING_PARTY_ID}/.default"
|
350
358
|
query.pop("resource")
|
351
359
|
else:
|
352
360
|
query["scope"] = "openid"
|
@@ -1,6 +1,6 @@
|
|
1
1
|
[tool.poetry]
|
2
2
|
name = 'django-auth-adfs'
|
3
|
-
version = "1.11.
|
3
|
+
version = "1.11.5" # Remember to also change __init__.py version
|
4
4
|
description = 'A Django authentication backend for Microsoft ADFS and AzureAD'
|
5
5
|
authors = ['Joris Beckers <joris.beckers@gmail.com>']
|
6
6
|
maintainers = ['Jonas Krüger Svensson <jonas-ks@hotmail.com>', 'Sondre Lillebø Gundersen <sondrelg@live.no>']
|
@@ -25,6 +25,7 @@ classifiers = [
|
|
25
25
|
'Programming Language :: Python :: 3.8',
|
26
26
|
'Programming Language :: Python :: 3.9',
|
27
27
|
'Programming Language :: Python :: 3.10',
|
28
|
+
'Programming Language :: Python :: 3.11',
|
28
29
|
'Topic :: Internet :: WWW/HTTP',
|
29
30
|
'Topic :: Internet :: WWW/HTTP :: Dynamic Content',
|
30
31
|
'Topic :: Internet :: WWW/HTTP :: WSGI',
|
@@ -41,7 +42,7 @@ django = [
|
|
41
42
|
]
|
42
43
|
requests = '^1 || ^2'
|
43
44
|
urllib3 = '^1.26.0'
|
44
|
-
cryptography = '>=1.7,<
|
45
|
+
cryptography = '>=1.7,<40.0'
|
45
46
|
PyJWT = "^2.4.0"
|
46
47
|
|
47
48
|
[tool.poetry.dev-dependencies]
|
django-auth-adfs-1.11.1/setup.py
DELETED
@@ -1,38 +0,0 @@
|
|
1
|
-
# -*- coding: utf-8 -*-
|
2
|
-
from setuptools import setup
|
3
|
-
|
4
|
-
packages = \
|
5
|
-
['django_auth_adfs']
|
6
|
-
|
7
|
-
package_data = \
|
8
|
-
{'': ['*'], 'django_auth_adfs': ['templates/django_auth_adfs/*']}
|
9
|
-
|
10
|
-
install_requires = \
|
11
|
-
['PyJWT>=2.4.0,<3.0.0',
|
12
|
-
'cryptography>=1.7,<39.0',
|
13
|
-
'requests>=1,<3',
|
14
|
-
'urllib3>=1.26.0,<2.0.0']
|
15
|
-
|
16
|
-
extras_require = \
|
17
|
-
{':python_version <= "3.7"': ['django>=3,<4'],
|
18
|
-
':python_version >= "3.8"': ['django>=3,<5']}
|
19
|
-
|
20
|
-
setup_kwargs = {
|
21
|
-
'name': 'django-auth-adfs',
|
22
|
-
'version': '1.11.1',
|
23
|
-
'description': 'A Django authentication backend for Microsoft ADFS and AzureAD',
|
24
|
-
'long_description': 'ADFS Authentication for Django\n==============================\n\n.. image:: https://readthedocs.org/projects/django-auth-adfs/badge/?version=latest\n :target: http://django-auth-adfs.readthedocs.io/en/latest/?badge=latest\n :alt: Documentation Status\n.. image:: https://img.shields.io/pypi/v/django-auth-adfs.svg\n :target: https://pypi.python.org/pypi/django-auth-adfs\n.. image:: https://img.shields.io/pypi/pyversions/django-auth-adfs.svg\n :target: https://pypi.python.org/pypi/django-auth-adfs#downloads\n.. image:: https://img.shields.io/pypi/djversions/django-auth-adfs.svg\n :target: https://pypi.python.org/pypi/django-auth-adfs\n.. image:: https://codecov.io/github/snok/django-auth-adfs/coverage.svg?branch=master\n :target: https://codecov.io/github/snok/django-auth-adfs?branch=master\n\nA Django authentication backend for Microsoft ADFS and Azure AD\n\n* Free software: BSD License\n* Homepage: https://github.com/snok/django-auth-adfs\n* Documentation: http://django-auth-adfs.readthedocs.io/\n\nFeatures\n--------\n\n* Integrates Django with Active Directory on Windows 2012 R2, 2016 or Azure AD in the cloud.\n* Provides seamless single sign on (SSO) for your Django project on intranet environments.\n* Auto creates users and adds them to Django groups based on info received from ADFS.\n* Django Rest Framework (DRF) integration: Authenticate against your API with an ADFS access token.\n\nInstallation\n------------\n\nPython package::\n\n pip install django-auth-adfs\n\nIn your project\'s ``settings.py`` add these settings.\n\n.. code-block:: python\n\n AUTHENTICATION_BACKENDS = (\n ...\n \'django_auth_adfs.backend.AdfsAuthCodeBackend\',\n ...\n )\n\n INSTALLED_APPS = (\n ...\n # Needed for the ADFS redirect URI to function\n \'django_auth_adfs\',\n ...\n\n # checkout the documentation for more settings\n AUTH_ADFS = {\n "SERVER": "adfs.yourcompany.com",\n "CLIENT_ID": "your-configured-client-id",\n "RELYING_PARTY_ID": "your-adfs-RPT-name",\n # Make sure to read the documentation about the AUDIENCE setting\n # when you configured the identifier as a URL!\n "AUDIENCE": "microsoft:identityserver:your-RelyingPartyTrust-identifier",\n "CA_BUNDLE": "/path/to/ca-bundle.pem",\n "CLAIM_MAPPING": {"first_name": "given_name",\n "last_name": "family_name",\n "email": "email"},\n }\n\n # Configure django to redirect users to the right URL for login\n LOGIN_URL = "django_auth_adfs:login"\n LOGIN_REDIRECT_URL = "/"\n\n ########################\n # OPTIONAL SETTINGS\n ########################\n\n MIDDLEWARE = (\n ...\n # With this you can force a user to login without using\n # the LoginRequiredMixin on every view class\n #\n # You can specify URLs for which login is not enforced by\n # specifying them in the LOGIN_EXEMPT_URLS setting.\n \'django_auth_adfs.middleware.LoginRequiredMiddleware\',\n )\n\nIn your project\'s ``urls.py`` add these paths:\n\n.. code-block:: python\n\n urlpatterns = [\n ...\n path(\'oauth2/\', include(\'django_auth_adfs.urls\')),\n ]\n\nThis will add these paths to Django:\n\n* ``/oauth2/login`` where users are redirected to, to initiate the login with ADFS.\n* ``/oauth2/login_no_sso`` where users are redirected to, to initiate the login with ADFS but forcing a login screen.\n* ``/oauth2/callback`` where ADFS redirects back to after login. So make sure you set the redirect URI on ADFS to this.\n* ``/oauth2/logout`` which logs out the user from both Django and ADFS.\n\nYou can use them like this in your django templates:\n\n.. code-block:: html\n\n <a href="{% url \'django_auth_adfs:logout\' %}">Logout</a>\n <a href="{% url \'django_auth_adfs:login\' %}">Login</a>\n <a href="{% url \'django_auth_adfs:login-no-sso\' %}">Login (no SSO)</a>\n\nContributing\n------------\nContributions to the code are more then welcome.\nFor more details have a look at the ``CONTRIBUTING.rst`` file.\n',
|
25
|
-
'author': 'Joris Beckers',
|
26
|
-
'author_email': 'joris.beckers@gmail.com',
|
27
|
-
'maintainer': 'Jonas Krüger Svensson',
|
28
|
-
'maintainer_email': 'jonas-ks@hotmail.com',
|
29
|
-
'url': 'https://github.com/snok/django-auth-adfs',
|
30
|
-
'packages': packages,
|
31
|
-
'package_data': package_data,
|
32
|
-
'install_requires': install_requires,
|
33
|
-
'extras_require': extras_require,
|
34
|
-
'python_requires': '>=3.7,<4.0',
|
35
|
-
}
|
36
|
-
|
37
|
-
|
38
|
-
setup(**setup_kwargs)
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|