usso 0.27.9__tar.gz → 0.27.10__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.27.9/src/usso.egg-info → usso-0.27.10}/PKG-INFO +1 -1
- {usso-0.27.9 → usso-0.27.10}/pyproject.toml +1 -1
- {usso-0.27.9 → usso-0.27.10}/src/usso/session/async_session.py +13 -9
- {usso-0.27.9 → usso-0.27.10}/src/usso/session/base_session.py +11 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/session/session.py +20 -16
- {usso-0.27.9 → usso-0.27.10/src/usso.egg-info}/PKG-INFO +1 -1
- {usso-0.27.9 → usso-0.27.10}/LICENSE.txt +0 -0
- {usso-0.27.9 → usso-0.27.10}/README.md +0 -0
- {usso-0.27.9 → usso-0.27.10}/setup.cfg +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/__init__.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/b64tools.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/client/__init__.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/client/api.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/client/async_api.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/core.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/django/__init__.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/django/middleware.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/exceptions.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/fastapi/__init__.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/fastapi/integration.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/schemas.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso/session/__init__.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso.egg-info/SOURCES.txt +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso.egg-info/dependency_links.txt +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso.egg-info/entry_points.txt +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso.egg-info/requires.txt +0 -0
- {usso-0.27.9 → usso-0.27.10}/src/usso.egg-info/top_level.txt +0 -0
- {usso-0.27.9 → usso-0.27.10}/tests/test_api.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/tests/test_core.py +0 -0
- {usso-0.27.9 → usso-0.27.10}/tests/test_simple.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: usso
|
3
|
-
Version: 0.27.
|
3
|
+
Version: 0.27.10
|
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.27.
|
7
|
+
version = "0.27.10"
|
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"
|
@@ -14,17 +14,21 @@ class AsyncUssoSession(httpx.AsyncClient, BaseUssoSession):
|
|
14
14
|
refresh_token: str | None = os.getenv("USSO_REFRESH_TOKEN"),
|
15
15
|
usso_api_key: str | None = os.getenv("USSO_ADMIN_API_KEY"),
|
16
16
|
user_id: str | None = None,
|
17
|
+
client: "AsyncUssoSession" | None = None,
|
17
18
|
):
|
18
19
|
httpx.AsyncClient.__init__(self)
|
19
|
-
|
20
|
-
self
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
20
|
+
if client:
|
21
|
+
self.copy_attributes_from(client)
|
22
|
+
else:
|
23
|
+
BaseUssoSession.__init__(
|
24
|
+
self,
|
25
|
+
usso_base_url=usso_base_url,
|
26
|
+
api_key=api_key,
|
27
|
+
usso_refresh_url=usso_refresh_url,
|
28
|
+
refresh_token=refresh_token,
|
29
|
+
usso_api_key=usso_api_key,
|
30
|
+
user_id=user_id,
|
31
|
+
)
|
28
32
|
self._refresh_sync()
|
29
33
|
|
30
34
|
def _prepare_refresh_request(self) -> tuple[dict, dict]:
|
@@ -27,6 +27,7 @@ class BaseUssoSession:
|
|
27
27
|
if usso_base_url.endswith("/"):
|
28
28
|
usso_base_url = usso_base_url[:-1]
|
29
29
|
|
30
|
+
self.usso_base_url = usso_base_url
|
30
31
|
self.usso_refresh_url = usso_refresh_url or f"{usso_base_url}/auth/refresh"
|
31
32
|
self._refresh_token = refresh_token
|
32
33
|
self.access_token = None
|
@@ -37,6 +38,16 @@ class BaseUssoSession:
|
|
37
38
|
if api_key:
|
38
39
|
self.headers.update({"x-api-key": api_key})
|
39
40
|
|
41
|
+
def copy_attributes_from(self, client: "BaseUssoSession"):
|
42
|
+
self.usso_base_url = client.usso_base_url
|
43
|
+
self.usso_refresh_url = client.usso_refresh_url
|
44
|
+
self._refresh_token = client._refresh_token
|
45
|
+
self.access_token = client.access_token
|
46
|
+
self.api_key = client.api_key
|
47
|
+
self.usso_api_key = client.usso_api_key
|
48
|
+
self.user_id = client.user_id
|
49
|
+
self.headers = client.headers.copy()
|
50
|
+
|
40
51
|
@property
|
41
52
|
def refresh_token(self):
|
42
53
|
if self._refresh_token and is_expired(self._refresh_token):
|
@@ -1,12 +1,12 @@
|
|
1
1
|
import os
|
2
2
|
|
3
|
-
import
|
3
|
+
import httpx
|
4
4
|
from usso.core import is_expired
|
5
5
|
|
6
6
|
from .base_session import BaseUssoSession
|
7
7
|
|
8
8
|
|
9
|
-
class UssoSession(BaseUssoSession,
|
9
|
+
class UssoSession(BaseUssoSession, httpx.Client):
|
10
10
|
|
11
11
|
def __init__(
|
12
12
|
self,
|
@@ -17,24 +17,28 @@ class UssoSession(BaseUssoSession, requests.Session):
|
|
17
17
|
refresh_token: str | None = os.getenv("USSO_REFRESH_TOKEN"),
|
18
18
|
usso_api_key: str | None = os.getenv("USSO_ADMIN_API_KEY"),
|
19
19
|
user_id: str | None = None,
|
20
|
+
client: "UssoSession" | None = None,
|
20
21
|
):
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
22
|
+
httpx.Client.__init__(self)
|
23
|
+
|
24
|
+
if client:
|
25
|
+
self.copy_attributes_from(client)
|
26
|
+
else:
|
27
|
+
BaseUssoSession.__init__(
|
28
|
+
self,
|
29
|
+
usso_base_url=usso_base_url,
|
30
|
+
api_key=api_key,
|
31
|
+
usso_refresh_url=usso_refresh_url,
|
32
|
+
refresh_token=refresh_token,
|
33
|
+
usso_api_key=usso_api_key,
|
34
|
+
user_id=user_id,
|
35
|
+
)
|
31
36
|
self._refresh()
|
32
|
-
self.headers.update(self.headers)
|
33
37
|
|
34
38
|
def _refresh_api(self):
|
35
39
|
assert self.usso_api_key, "usso_api_key is required"
|
36
40
|
params = {"user_id": self.user_id} if self.user_id else {}
|
37
|
-
response =
|
41
|
+
response = httpx.get(
|
38
42
|
f"{self.usso_refresh_url}/api",
|
39
43
|
headers={"x-api-key": self.usso_api_key},
|
40
44
|
params=params,
|
@@ -51,7 +55,7 @@ class UssoSession(BaseUssoSession, requests.Session):
|
|
51
55
|
if self.usso_api_key and not self.refresh_token:
|
52
56
|
self._refresh_api()
|
53
57
|
|
54
|
-
response =
|
58
|
+
response = httpx.post(
|
55
59
|
self.usso_refresh_url, json={"refresh_token": f"{self.refresh_token}"}
|
56
60
|
)
|
57
61
|
response.raise_for_status()
|
@@ -69,4 +73,4 @@ class UssoSession(BaseUssoSession, requests.Session):
|
|
69
73
|
|
70
74
|
def _request(self, method: str, url: str, **kwargs):
|
71
75
|
self.get_session()
|
72
|
-
return
|
76
|
+
return super().request(self, method, url, **kwargs)
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: usso
|
3
|
-
Version: 0.27.
|
3
|
+
Version: 0.27.10
|
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>
|
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
|