usso 0.27.9__py3-none-any.whl → 0.27.10__py3-none-any.whl

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.
@@ -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
- BaseUssoSession.__init__(
20
- self,
21
- usso_base_url=usso_base_url,
22
- api_key=api_key,
23
- usso_refresh_url=usso_refresh_url,
24
- refresh_token=refresh_token,
25
- usso_api_key=usso_api_key,
26
- user_id=user_id,
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):
usso/session/session.py CHANGED
@@ -1,12 +1,12 @@
1
1
  import os
2
2
 
3
- import requests
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, requests.Session):
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
- requests.Session.__init__(self)
22
- BaseUssoSession.__init__(
23
- self,
24
- usso_base_url=usso_base_url,
25
- api_key=api_key,
26
- usso_refresh_url=usso_refresh_url,
27
- refresh_token=refresh_token,
28
- usso_api_key=usso_api_key,
29
- user_id=user_id,
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 = requests.get(
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 = requests.post(
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 requests.Session.request(self, method, url, **kwargs)
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.9
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>
@@ -11,12 +11,12 @@ usso/django/middleware.py,sha256=EEEpHvMQ6QiWw2HY8zQ2Aec0RCATcLWsCKeyiPWJKio,324
11
11
  usso/fastapi/__init__.py,sha256=0EcdOzb4f3yu9nILIdGWnlyUz-0VaVX2az1e3f2BusI,201
12
12
  usso/fastapi/integration.py,sha256=IonxxNj_B9sG2j672rIzE047qo972vk7ch4-eGENp3Q,2638
13
13
  usso/session/__init__.py,sha256=tE4qWUdSI7iN_pywm47Mg8NKOTBa2nCNwCy3wCZWRmU,124
14
- usso/session/async_session.py,sha256=yOWePytbrPrN489xLGFm3jz-dW0I_esRrnGoDwXcKx0,3412
15
- usso/session/base_session.py,sha256=1A12QulP6UHe1lqYEihGAcBaZ_7C09EWZt3fB6JvbOE,2347
16
- usso/session/session.py,sha256=us23VzndGIyBW1TbtfL_qwmMobG9ciGuoDlsgraJUkQ,2357
17
- usso-0.27.9.dist-info/LICENSE.txt,sha256=ceC9ZJOV9H6CtQDcYmHOS46NA3dHJ_WD4J9blH513pc,1081
18
- usso-0.27.9.dist-info/METADATA,sha256=u_q1K9l6YiNxatNEWwp_WzIW0UoeWSxYxjYHTFh9QeE,4528
19
- usso-0.27.9.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
20
- usso-0.27.9.dist-info/entry_points.txt,sha256=4Zgpm5ELaAWPf0jPGJFz1_X69H7un8ycT3WdGoJ0Vvk,35
21
- usso-0.27.9.dist-info/top_level.txt,sha256=g9Jf6h1Oyidh0vPiFni7UHInTJjSvu6cUalpLTIvthg,5
22
- usso-0.27.9.dist-info/RECORD,,
14
+ usso/session/async_session.py,sha256=Q7Rbw5z5tiiagNEvRR26SP7zCvwtV5DTWnanQWghvms,3577
15
+ usso/session/base_session.py,sha256=Hs5ZEME04TJF3qNfk2gqD81Ib9UTZw_ArDRELxnSYVM,2829
16
+ usso/session/session.py,sha256=PHVkDACeSCP7h2Pn38SEl905akwyRbk38gk6-KD8fqI,2450
17
+ usso-0.27.10.dist-info/LICENSE.txt,sha256=ceC9ZJOV9H6CtQDcYmHOS46NA3dHJ_WD4J9blH513pc,1081
18
+ usso-0.27.10.dist-info/METADATA,sha256=7T5zV2MktxkK_Wq-MTHXg0yR0OseSear_9liczD51ks,4529
19
+ usso-0.27.10.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
20
+ usso-0.27.10.dist-info/entry_points.txt,sha256=4Zgpm5ELaAWPf0jPGJFz1_X69H7un8ycT3WdGoJ0Vvk,35
21
+ usso-0.27.10.dist-info/top_level.txt,sha256=g9Jf6h1Oyidh0vPiFni7UHInTJjSvu6cUalpLTIvthg,5
22
+ usso-0.27.10.dist-info/RECORD,,
File without changes