usso 0.28.19__tar.gz → 0.28.21__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {usso-0.28.19/src/usso.egg-info → usso-0.28.21}/PKG-INFO +1 -1
- {usso-0.28.19 → usso-0.28.21}/pyproject.toml +1 -1
- {usso-0.28.19 → usso-0.28.21}/src/usso/auth/authorization.py +16 -9
- {usso-0.28.19 → usso-0.28.21/src/usso.egg-info}/PKG-INFO +1 -1
- {usso-0.28.19 → usso-0.28.21}/tests/test_authorization.py +5 -0
- {usso-0.28.19 → usso-0.28.21}/LICENSE.txt +0 -0
- {usso-0.28.19 → usso-0.28.21}/MANIFEST.in +0 -0
- {usso-0.28.19 → usso-0.28.21}/README.md +0 -0
- {usso-0.28.19 → usso-0.28.21}/pytest.ini +0 -0
- {usso-0.28.19 → usso-0.28.21}/setup.cfg +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/__init__.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/auth/__init__.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/auth/api_key.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/auth/client.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/auth/config.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/exceptions.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/integrations/django/__init__.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/integrations/django/middleware.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/integrations/fastapi/__init__.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/integrations/fastapi/dependency.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/integrations/fastapi/handler.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/models/user.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/session/__init__.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/session/async_session.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/session/base_session.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/session/session.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/utils/__init__.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/utils/method_utils.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso/utils/string_utils.py +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso.egg-info/SOURCES.txt +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso.egg-info/dependency_links.txt +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso.egg-info/entry_points.txt +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso.egg-info/requires.txt +0 -0
- {usso-0.28.19 → usso-0.28.21}/src/usso.egg-info/top_level.txt +0 -0
- {usso-0.28.19 → usso-0.28.21}/tests/test_fastapi.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: usso
|
3
|
-
Version: 0.28.
|
3
|
+
Version: 0.28.21
|
4
4
|
Summary: A plug-and-play client for integrating universal single sign-on (SSO) with Python frameworks, enabling secure and seamless authentication across microservices.
|
5
5
|
Author-email: Mahdi Kiani <mahdikiany@gmail.com>
|
6
6
|
Maintainer-email: Mahdi Kiani <mahdikiany@gmail.com>
|
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
|
|
4
4
|
|
5
5
|
[project]
|
6
6
|
name = "usso"
|
7
|
-
version = "0.28.
|
7
|
+
version = "0.28.21"
|
8
8
|
description = "A plug-and-play client for integrating universal single sign-on (SSO) with Python frameworks, enabling secure and seamless authentication across microservices."
|
9
9
|
readme = "README.md"
|
10
10
|
requires-python = ">=3.9"
|
@@ -1,6 +1,5 @@
|
|
1
1
|
import fnmatch
|
2
|
-
import
|
3
|
-
from urllib.parse import parse_qs, urlparse
|
2
|
+
from urllib.parse import parse_qs
|
4
3
|
|
5
4
|
PRIVILEGE_LEVELS = {
|
6
5
|
"read": 10,
|
@@ -33,12 +32,22 @@ def parse_scope(scope: str) -> tuple[str, list[str], dict[str, str]]:
|
|
33
32
|
- filters: dict[str, str]
|
34
33
|
"""
|
35
34
|
|
36
|
-
|
37
|
-
|
38
|
-
|
35
|
+
colon_idx = scope.find(":")
|
36
|
+
question_idx = scope.find("?")
|
37
|
+
if question_idx == -1:
|
38
|
+
question_idx = len(scope)
|
39
|
+
|
40
|
+
if colon_idx != -1 and colon_idx < question_idx:
|
41
|
+
action = scope[:colon_idx]
|
42
|
+
resource_path = scope[colon_idx + 1 : question_idx]
|
43
|
+
else:
|
44
|
+
action = ""
|
45
|
+
resource_path = scope[:question_idx]
|
46
|
+
|
47
|
+
query = scope[question_idx + 1 :]
|
39
48
|
filters = {k: v[0] for k, v in parse_qs(query).items()}
|
40
|
-
|
41
|
-
return
|
49
|
+
resource_path_parts = resource_path.split("/") if resource_path else ["*"]
|
50
|
+
return action, resource_path_parts, filters
|
42
51
|
|
43
52
|
|
44
53
|
def is_path_match(
|
@@ -205,8 +214,6 @@ def is_subset_scope(*, subset_scope: str, super_scope: str) -> bool:
|
|
205
214
|
if child_filters.get(k) != v:
|
206
215
|
return False
|
207
216
|
|
208
|
-
logging.error(f"{parent_level}, {child_level}")
|
209
|
-
|
210
217
|
return True
|
211
218
|
|
212
219
|
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: usso
|
3
|
-
Version: 0.28.
|
3
|
+
Version: 0.28.21
|
4
4
|
Summary: A plug-and-play client for integrating universal single sign-on (SSO) with Python frameworks, enabling secure and seamless authentication across microservices.
|
5
5
|
Author-email: Mahdi Kiani <mahdikiany@gmail.com>
|
6
6
|
Maintainer-email: Mahdi Kiani <mahdikiany@gmail.com>
|
@@ -210,3 +210,8 @@ def test_scope_subset():
|
|
210
210
|
assert not is_subset_scope(
|
211
211
|
subset_scope="create:files", super_scope="files"
|
212
212
|
)
|
213
|
+
assert not is_subset_scope(subset_scope="create:files", super_scope="*")
|
214
|
+
assert is_subset_scope(subset_scope="create:files", super_scope="*:*")
|
215
|
+
assert is_subset_scope(
|
216
|
+
subset_scope="create:files", super_scope="*://files"
|
217
|
+
)
|
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
|
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
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|