clear-skies 1.19.20__py3-none-any.whl → 1.19.21__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.
Potentially problematic release.
This version of clear-skies might be problematic. Click here for more details.
- {clear_skies-1.19.20.dist-info → clear_skies-1.19.21.dist-info}/METADATA +3 -1
- {clear_skies-1.19.20.dist-info → clear_skies-1.19.21.dist-info}/RECORD +6 -5
- clearskies/authentication/__init__.py +7 -0
- clearskies/authentication/jwks_jwcrypto.py +39 -0
- {clear_skies-1.19.20.dist-info → clear_skies-1.19.21.dist-info}/LICENSE +0 -0
- {clear_skies-1.19.20.dist-info → clear_skies-1.19.21.dist-info}/WHEEL +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: clear-skies
|
|
3
|
-
Version: 1.19.
|
|
3
|
+
Version: 1.19.21
|
|
4
4
|
Summary: A framework for building backends in the cloud
|
|
5
5
|
Home-page: https://github.com/cmancone/clearskies
|
|
6
6
|
License: MIT
|
|
@@ -15,12 +15,14 @@ Classifier: Programming Language :: Python :: 3.10
|
|
|
15
15
|
Classifier: Programming Language :: Python :: 3.11
|
|
16
16
|
Classifier: Topic :: Software Development :: Libraries :: Application Frameworks
|
|
17
17
|
Provides-Extra: jose
|
|
18
|
+
Provides-Extra: jwcrypto
|
|
18
19
|
Provides-Extra: mysql
|
|
19
20
|
Provides-Extra: secrets
|
|
20
21
|
Requires-Dist: akeyless (>=3.6.2,<4.0.0) ; extra == "secrets"
|
|
21
22
|
Requires-Dist: akeyless-cloud-id (>=0.2.3,<0.3.0) ; extra == "secrets"
|
|
22
23
|
Requires-Dist: dateparser (>=1.1.8,<2.0.0)
|
|
23
24
|
Requires-Dist: jose (>=1.0.0,<2.0.0) ; extra == "jose"
|
|
25
|
+
Requires-Dist: jwcrypto (>=1.5.6,<2.0.0) ; extra == "jwcrypto"
|
|
24
26
|
Requires-Dist: pymysql (>=1.1.0,<2.0.0) ; extra == "mysql"
|
|
25
27
|
Requires-Dist: requests (>=2.31.0,<3.0.0)
|
|
26
28
|
Project-URL: Repository, https://github.com/cmancone/clearskies
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
clearskies/__init__.py,sha256=Iz_VxSgiqM6VtGXoUsB_yVKFy_uWvcf071w803wJ8EE,832
|
|
2
2
|
clearskies/application.py,sha256=_gYGIUGdVE5fAS9dwxRZ1gDpDjqGo7-twVt_VxI6XVE,966
|
|
3
|
-
clearskies/authentication/__init__.py,sha256=
|
|
3
|
+
clearskies/authentication/__init__.py,sha256=pHKJOfujgvNAbgzQpKVzEhWORwjAZTE4jKhJ50M7zts,900
|
|
4
4
|
clearskies/authentication/auth0_jwks.py,sha256=bzqNaEoG_iPndwttRXuaKpgkDtgOCLAooyifl0I0ACI,4447
|
|
5
5
|
clearskies/authentication/auth_exception.py,sha256=8Tay3Sim2K8vAZ6ldisSJyRyN0cwX7iyGHwfglSKW_A,41
|
|
6
6
|
clearskies/authentication/authorization.py,sha256=eLzBrXMNr1gYoIBZTd8I6uH3R0CfMMjhvimkJt4Amrs,601
|
|
7
7
|
clearskies/authentication/jwks.py,sha256=JsBG4U7eGoKO75CV6J39d91lrVWtjVn6n8fN9RpCYEc,2811
|
|
8
|
+
clearskies/authentication/jwks_jwcrypto.py,sha256=Oq3lID1nXSSaBnmxzpz1TSByvyNbanUHNAmdqDsuM6k,1219
|
|
8
9
|
clearskies/authentication/public.py,sha256=zNpglAILTU7koz22YaGpMOAtTn_dG8dAP4Q9REdbaOk,630
|
|
9
10
|
clearskies/authentication/secret_bearer.py,sha256=OBkjvw4n-ZLRRtZEKyzdael03DYIwacvUxrj5V9h0Ow,2968
|
|
10
11
|
clearskies/autodoc/__init__.py,sha256=JRUAmd0he8iGlgiZvxewLMIXJqnOFEdvlaKAtHpC2lo,124
|
|
@@ -199,7 +200,7 @@ clearskies/tests/simple_api/models/__init__.py,sha256=nUA0W6fgXw_Bxa9CudkaDkC80t
|
|
|
199
200
|
clearskies/tests/simple_api/models/status.py,sha256=PEhPbaQh5qdUNHp8O0gz91LOLENAEBtqSaHxUPXchaM,699
|
|
200
201
|
clearskies/tests/simple_api/models/user.py,sha256=5_P4Tp1tTdX7PkMJ__epPM5MA7JAeVYGas69vcWloLc,819
|
|
201
202
|
clearskies/tests/simple_api/users_api.py,sha256=KYXCgEofDxHeRdQK67txN5oYUPvxxmB8JTku7L-apk4,2344
|
|
202
|
-
clear_skies-1.19.
|
|
203
|
-
clear_skies-1.19.
|
|
204
|
-
clear_skies-1.19.
|
|
205
|
-
clear_skies-1.19.
|
|
203
|
+
clear_skies-1.19.21.dist-info/LICENSE,sha256=3Ehd0g3YOpCj8sqj0Xjq5qbOtjjgk9qzhhD9YjRQgOA,1053
|
|
204
|
+
clear_skies-1.19.21.dist-info/METADATA,sha256=bfO7PgqWiYWKhHbfeXfUeXfN3Ku9UVvKNYkAyKLh1rI,1712
|
|
205
|
+
clear_skies-1.19.21.dist-info/WHEEL,sha256=d2fvjOD7sXsVzChCqf0Ty0JbHKBaLYwDbGQDwQTnJ50,88
|
|
206
|
+
clear_skies-1.19.21.dist-info/RECORD,,
|
|
@@ -4,6 +4,7 @@ from .public import Public
|
|
|
4
4
|
from .auth0_jwks import Auth0JWKS
|
|
5
5
|
from .authorization import Authorization
|
|
6
6
|
from .jwks import JWKS
|
|
7
|
+
from .jwks_jwcrypto import JWKSJwCrypto
|
|
7
8
|
|
|
8
9
|
|
|
9
10
|
def public():
|
|
@@ -22,6 +23,10 @@ def jwks(jwks_url, **kwargs):
|
|
|
22
23
|
return BindingConfig(JWKS, jwks_url=jwks_url, **kwargs)
|
|
23
24
|
|
|
24
25
|
|
|
26
|
+
def jwks_jwcrypto(jwks_url, **kwargs):
|
|
27
|
+
return BindingConfig(JWKSJwCrypto, jwks_url=jwks_url, **kwargs)
|
|
28
|
+
|
|
29
|
+
|
|
25
30
|
__all__ = [
|
|
26
31
|
"Authorization",
|
|
27
32
|
"BindingConfig",
|
|
@@ -34,4 +39,6 @@ __all__ = [
|
|
|
34
39
|
"authorization",
|
|
35
40
|
"jwks",
|
|
36
41
|
"JWKS",
|
|
42
|
+
"jwks_jwcrypto",
|
|
43
|
+
"JWKSJwCrypto",
|
|
37
44
|
]
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import datetime
|
|
2
|
+
import json
|
|
3
|
+
|
|
4
|
+
from clearskies.authentication import JWKS
|
|
5
|
+
from clearskies.handlers.exceptions import ClientError
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class JWKSJwCrypto(JWKS):
|
|
9
|
+
def __init__(self, environment, requests):
|
|
10
|
+
# the third parameter is supposed to be jose_jwt, but we're going to override all
|
|
11
|
+
# the functions that use it
|
|
12
|
+
super().__init__(environment, requests, {})
|
|
13
|
+
|
|
14
|
+
def validate_jwt(self, raw_jwt):
|
|
15
|
+
from jwcrypto import jws, jwk, jwt
|
|
16
|
+
from jwcrypto.common import JWException
|
|
17
|
+
|
|
18
|
+
keys = jwk.JWKSet()
|
|
19
|
+
keys.import_keyset(json.dumps(self._get_jwks()))
|
|
20
|
+
|
|
21
|
+
client_jwt = jwt.JWT()
|
|
22
|
+
try:
|
|
23
|
+
client_jwt.deserialize(raw_jwt)
|
|
24
|
+
except Exception as e:
|
|
25
|
+
raise ClientError(str(e))
|
|
26
|
+
|
|
27
|
+
try:
|
|
28
|
+
client_jwt.validate(keys)
|
|
29
|
+
self.jwt_claims = json.loads(client_jwt.claims)
|
|
30
|
+
except JWException as e:
|
|
31
|
+
raise ClientError(str(e))
|
|
32
|
+
|
|
33
|
+
if self._audience and self.jwt_claims.get("aud") != self._audience:
|
|
34
|
+
raise ClientError("Audience does not match")
|
|
35
|
+
|
|
36
|
+
if self._issuer and self.jwt_claims.get("iss") != self._issuer:
|
|
37
|
+
raise ClientError("Issuer does not match")
|
|
38
|
+
|
|
39
|
+
return True
|
|
File without changes
|
|
File without changes
|