usso 0.27.17__py3-none-any.whl → 0.27.19__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.
usso/client/api.py CHANGED
@@ -15,6 +15,7 @@ class UssoAPI(metaclass=Singleton):
15
15
  ):
16
16
  if url and not url.startswith("http"):
17
17
  url = f"https://{url}"
18
+ url = url.rstrip("/")
18
19
  self.url = url
19
20
  assert (
20
21
  api_key or refresh_token
usso/client/async_api.py CHANGED
@@ -15,6 +15,7 @@ class AsyncUssoAPI(metaclass=Singleton):
15
15
  ):
16
16
  if url and not url.startswith("http"):
17
17
  url = f"https://{url}"
18
+ url = url.rstrip("/")
18
19
  self.url = url
19
20
  assert (
20
21
  api_key or refresh_token
usso/core.py CHANGED
@@ -79,11 +79,15 @@ def decode_token_with_jwk(jwk_url: str, token: str, **kwargs) -> UserData | None
79
79
 
80
80
  @cachetools.func.ttl_cache(maxsize=128, ttl=10 * 60)
81
81
  def fetch_api_key_data(jwk_url: str, api_key: str):
82
- parsed = urlparse(jwk_url)
83
- url = f"{parsed.scheme}://{parsed.netloc}/api_key/verify"
84
- response = httpx.post(url, json={"api_key": api_key})
85
- response.raise_for_status()
86
- return UserData(**response.json())
82
+ try:
83
+ parsed = urlparse(jwk_url)
84
+ url = f"{parsed.scheme}://{parsed.netloc}/api_key/verify"
85
+ response = httpx.post(url, json={"api_key": api_key})
86
+ response.raise_for_status()
87
+ return UserData(**response.json())
88
+ except Exception as e:
89
+ _handle_exception("error", message=str(e))
90
+
87
91
 
88
92
 
89
93
  class Usso:
@@ -2,47 +2,80 @@ import os
2
2
  from urllib.parse import urlparse
3
3
 
4
4
  from usso.core import is_expired
5
+ from typing import Optional, Any, Callable
6
+ import inspect
7
+
5
8
 
6
9
 
7
10
  class BaseUssoSession:
8
11
 
9
12
  def __init__(
10
13
  self,
11
- usso_base_url: str | None = os.getenv("USSO_URL"),
12
- api_key: str | None = os.getenv("USSO_API_KEY"),
13
- usso_refresh_url: str | None = os.getenv("USSO_REFRESH_URL"),
14
- refresh_token: str | None = os.getenv("USSO_REFRESH_TOKEN"),
15
- usso_api_key: str | None = os.getenv("USSO_ADMIN_API_KEY"),
14
+ api_key: str | None = None,
15
+ *,
16
+ usso_base_url: str | None = None,
17
+ usso_refresh_url: str | None = None,
18
+ refresh_token: str | None = None,
19
+ app_id: str | None = None,
20
+ app_secret: str | None = None,
21
+ access_token: str | None = None,
22
+ usso_admin_api_key: str | None = None,
16
23
  user_id: str | None = None,
17
- client: "BaseUssoSession" = None,
24
+ client: Optional["BaseUssoSession"] = None,
25
+ **kwargs,
18
26
  ):
19
27
  if client:
20
28
  self.copy_attributes_from(client)
21
29
  return
22
30
 
23
- assert (
24
- usso_base_url or usso_refresh_url
25
- ), "usso_base_url or usso_refresh_url is required"
26
- assert (
27
- refresh_token or api_key or usso_api_key
28
- ), "refresh_token or api_key or usso_api_key is required"
31
+ if not (api_key or usso_base_url or usso_refresh_url):
32
+ if os.getenv("USSO_API_KEY"):
33
+ api_key = os.getenv("USSO_API_KEY")
34
+ elif os.getenv("USSO_URL"):
35
+ usso_base_url = os.getenv("USSO_URL")
36
+ elif os.getenv("USSO_REFRESH_URL"):
37
+ usso_refresh_url = os.getenv("USSO_REFRESH_URL")
38
+ else:
39
+ raise ValueError(
40
+ "one of api_key, usso_base_url or usso_refresh_url is required"
41
+ )
42
+
43
+ if not (
44
+ api_key
45
+ or refresh_token
46
+ or usso_admin_api_key
47
+ or (app_id and app_secret)
48
+ or access_token
49
+ ):
50
+ if os.getenv("USSO_REFRESH_TOKEN"):
51
+ refresh_token = os.getenv("USSO_REFRESH_TOKEN")
52
+ elif os.getenv("USSO_ADMIN_API_KEY"):
53
+ usso_admin_api_key = os.getenv("USSO_ADMIN_API_KEY")
54
+ elif os.getenv("USSO_APP_ID") and os.getenv("USSO_APP_SECRET"):
55
+ app_id = os.getenv("USSO_APP_ID")
56
+ app_secret = os.getenv("USSO_APP_SECRET")
57
+ else:
58
+ raise ValueError(
59
+ "one of api_key, refresh_token, usso_admin_api_key, app_id and app_secret or access_token is required"
60
+ )
61
+
62
+ if api_key:
63
+ self.api_key = api_key
64
+ self.headers.update({"x-api-key": api_key})
29
65
 
30
66
  if not usso_base_url:
31
67
  url_parts = urlparse(usso_refresh_url)
32
68
  usso_base_url = f"{url_parts.scheme}://{url_parts.netloc}"
33
- if usso_base_url.endswith("/"):
69
+ elif usso_base_url.endswith("/"):
34
70
  usso_base_url = usso_base_url[:-1]
35
71
 
36
72
  self.usso_base_url = usso_base_url
37
73
  self.usso_refresh_url = usso_refresh_url or f"{usso_base_url}/auth/refresh"
38
74
  self._refresh_token = refresh_token
39
75
  self.access_token = None
40
- self.api_key = api_key
41
- self.usso_api_key = usso_api_key
76
+ self.usso_admin_api_key = usso_admin_api_key
42
77
  self.user_id = user_id
43
78
  self.headers = getattr(self, "headers", {})
44
- if self.api_key:
45
- self.headers.update({"x-api-key": api_key})
46
79
 
47
80
  def copy_attributes_from(self, client: "BaseUssoSession"):
48
81
  self.usso_base_url = client.usso_base_url
@@ -50,7 +83,7 @@ class BaseUssoSession:
50
83
  self._refresh_token = client._refresh_token
51
84
  self.access_token = client.access_token
52
85
  self.api_key = client.api_key
53
- self.usso_api_key = client.usso_api_key
86
+ self.usso_admin_api_key = client.usso_admin_api_key
54
87
  self.user_id = client.user_id
55
88
  self.headers = client.headers.copy()
56
89
 
@@ -60,27 +93,3 @@ class BaseUssoSession:
60
93
  self._refresh_token = None
61
94
 
62
95
  return self._refresh_token
63
-
64
- def request(self, method: str, url: str, **kwargs):
65
- return self._request(method, url, **kwargs)
66
-
67
- def get(self, url: str, **kwargs):
68
- return self._request("GET", url, **kwargs)
69
-
70
- def post(self, url: str, **kwargs):
71
- return self._request("POST", url, **kwargs)
72
-
73
- def put(self, url: str, **kwargs):
74
- return self._request("PUT", url, **kwargs)
75
-
76
- def patch(self, url: str, **kwargs):
77
- return self._request("PATCH", url, **kwargs)
78
-
79
- def delete(self, url: str, **kwargs):
80
- return self._request("DELETE", url, **kwargs)
81
-
82
- def head(self, url: str, **kwargs):
83
- return self._request("HEAD", url, **kwargs)
84
-
85
- def options(self, url: str, **kwargs):
86
- return self._request("OPTIONS", url, **kwargs)
usso/session/session.py CHANGED
@@ -1,12 +1,12 @@
1
1
  import os
2
-
2
+ import inspect
3
+ from typing import Callable, Any
3
4
  import httpx
4
5
 
5
6
  from usso.core import is_expired
6
7
 
7
8
  from .base_session import BaseUssoSession
8
9
 
9
-
10
10
  class UssoSession(httpx.Client, BaseUssoSession):
11
11
 
12
12
  def __init__(
@@ -19,8 +19,12 @@ class UssoSession(httpx.Client, BaseUssoSession):
19
19
  usso_api_key: str | None = os.getenv("USSO_ADMIN_API_KEY"),
20
20
  user_id: str | None = None,
21
21
  client: "UssoSession" = None,
22
+ **kwargs,
22
23
  ):
23
- httpx.Client.__init__(self)
24
+
25
+ httpx_kwargs = _filter_kwargs(kwargs, httpx.Client.__init__)
26
+
27
+ httpx.Client.__init__(self, **httpx_kwargs)
24
28
 
25
29
  BaseUssoSession.__init__(
26
30
  self,
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.1
1
+ Metadata-Version: 2.2
2
2
  Name: usso
3
- Version: 0.27.17
3
+ Version: 0.27.19
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>
@@ -1,22 +1,22 @@
1
1
  usso/__init__.py,sha256=NnOS_S1a-JKTOlGe1nw-kCL3m0y82mA2mDraus7BQ2o,120
2
2
  usso/b64tools.py,sha256=HGQ0E59vzjrQo2-4jrcY03ebtTaYwTtCZ7KgJaEmxO0,610
3
- usso/core.py,sha256=R4WrOn5bkBJzAnvJZldfihfwNvMn0BnjoKkO5eCnDTA,5533
3
+ usso/core.py,sha256=kZCdHQz-sIbmd9MUd4CVMZACtvP60rbpL1Gszy3tkzQ,5641
4
4
  usso/exceptions.py,sha256=ogJsjdUK0HoZdQv5uCnzIVoG-bTTMHBqyvB4swAMsiE,653
5
5
  usso/schemas.py,sha256=aK_UWZvqjZLz5r1yBIZX_nL2yPCNUjxpZ93AsV9mAes,1810
6
6
  usso/client/__init__.py,sha256=ilGFrugI7bhGXVIcETdbRAye8S7k2mVjkEeziToVzSs,100
7
- usso/client/api.py,sha256=xlDq2nZNpq3mhAvqIbGEfANHNjJpPquSeULBfS7iMJw,5094
8
- usso/client/async_api.py,sha256=VBmuUsx9vBy-naeiVNhsGgJOTpD1z7VgH_23lazz3_4,5156
7
+ usso/client/api.py,sha256=-sluL8BMjcI1z8y8thZElCa63nxo25qlmKh3IzK3M6U,5124
8
+ usso/client/async_api.py,sha256=UMN84vmWvLgi-3zsNdhCOjf5zQQQFUJ-wKLztI_rU58,5186
9
9
  usso/django/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
10
10
  usso/django/middleware.py,sha256=EEEpHvMQ6QiWw2HY8zQ2Aec0RCATcLWsCKeyiPWJKio,3245
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
14
  usso/session/async_session.py,sha256=CLtgIXcLF0if_VX1x0IJK_RpVEu1waUw69x4YVj4xxU,3517
15
- usso/session/base_session.py,sha256=GyqsmAG5TsmM5LEcf8EjH31ObD9RQg7FC1_DLA8jBWw,2962
16
- usso/session/session.py,sha256=WnvT0wqBj_z0_N97oaqBleni36SJQdhK9r5k1roxcgY,2389
17
- usso-0.27.17.dist-info/LICENSE.txt,sha256=ceC9ZJOV9H6CtQDcYmHOS46NA3dHJ_WD4J9blH513pc,1081
18
- usso-0.27.17.dist-info/METADATA,sha256=mey2QJ0QdUeyuCYy1gmOdaR6LGETszjAcdArWz2DCS0,4580
19
- usso-0.27.17.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
20
- usso-0.27.17.dist-info/entry_points.txt,sha256=4Zgpm5ELaAWPf0jPGJFz1_X69H7un8ycT3WdGoJ0Vvk,35
21
- usso-0.27.17.dist-info/top_level.txt,sha256=g9Jf6h1Oyidh0vPiFni7UHInTJjSvu6cUalpLTIvthg,5
22
- usso-0.27.17.dist-info/RECORD,,
15
+ usso/session/base_session.py,sha256=wZ96VPf0zz8zDRtjJrOmZ2S4XvEBLLZAc74A4iDy7G4,3369
16
+ usso/session/session.py,sha256=aQ5EJ0o0unPz_JxFZWaF4ABwdu-Um9YZGnzCBTBG-bc,2540
17
+ usso-0.27.19.dist-info/LICENSE.txt,sha256=ceC9ZJOV9H6CtQDcYmHOS46NA3dHJ_WD4J9blH513pc,1081
18
+ usso-0.27.19.dist-info/METADATA,sha256=wrS64OzjjPXQVqW90LsVLdUCCZaDIc0vAuElYPn_grs,4580
19
+ usso-0.27.19.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
20
+ usso-0.27.19.dist-info/entry_points.txt,sha256=4Zgpm5ELaAWPf0jPGJFz1_X69H7un8ycT3WdGoJ0Vvk,35
21
+ usso-0.27.19.dist-info/top_level.txt,sha256=g9Jf6h1Oyidh0vPiFni7UHInTJjSvu6cUalpLTIvthg,5
22
+ usso-0.27.19.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: setuptools (75.6.0)
2
+ Generator: setuptools (75.8.0)
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
5
5