v0.1.0: CRM/ERP 系统内测版本 - 安全加固完成
- Docker bridge 网络隔离(8000 端口封死) - Gunicorn 4 Worker 多进程 - Alembic 数据库迁移基线 - 日志轮转 20m×3 - JWT 密钥 + DB 密码 + CORS 收紧 - 3-2-1 备份链路(NAS + R740-B 冷备) - 连接池 pool_pre_ping + pool_recycle=3600
This commit is contained in:
@@ -0,0 +1,79 @@
|
||||
from jose.backends.base import Key
|
||||
from jose.constants import ALGORITHMS
|
||||
from jose.exceptions import JWKError
|
||||
|
||||
try:
|
||||
from jose.backends import RSAKey # noqa: F401
|
||||
except ImportError:
|
||||
pass
|
||||
|
||||
try:
|
||||
from jose.backends import ECKey # noqa: F401
|
||||
except ImportError:
|
||||
pass
|
||||
|
||||
try:
|
||||
from jose.backends import AESKey # noqa: F401
|
||||
except ImportError:
|
||||
pass
|
||||
|
||||
try:
|
||||
from jose.backends import DIRKey # noqa: F401
|
||||
except ImportError:
|
||||
pass
|
||||
|
||||
try:
|
||||
from jose.backends import HMACKey # noqa: F401
|
||||
except ImportError:
|
||||
pass
|
||||
|
||||
|
||||
def get_key(algorithm):
|
||||
if algorithm in ALGORITHMS.KEYS:
|
||||
return ALGORITHMS.KEYS[algorithm]
|
||||
elif algorithm in ALGORITHMS.HMAC: # noqa: F811
|
||||
return HMACKey
|
||||
elif algorithm in ALGORITHMS.RSA:
|
||||
from jose.backends import RSAKey # noqa: F811
|
||||
|
||||
return RSAKey
|
||||
elif algorithm in ALGORITHMS.EC:
|
||||
from jose.backends import ECKey # noqa: F811
|
||||
|
||||
return ECKey
|
||||
elif algorithm in ALGORITHMS.AES:
|
||||
from jose.backends import AESKey # noqa: F811
|
||||
|
||||
return AESKey
|
||||
elif algorithm == ALGORITHMS.DIR:
|
||||
from jose.backends import DIRKey # noqa: F811
|
||||
|
||||
return DIRKey
|
||||
return None
|
||||
|
||||
|
||||
def register_key(algorithm, key_class):
|
||||
if not issubclass(key_class, Key):
|
||||
raise TypeError("Key class is not a subclass of jwk.Key")
|
||||
ALGORITHMS.KEYS[algorithm] = key_class
|
||||
ALGORITHMS.SUPPORTED.add(algorithm)
|
||||
return True
|
||||
|
||||
|
||||
def construct(key_data, algorithm=None):
|
||||
"""
|
||||
Construct a Key object for the given algorithm with the given
|
||||
key_data.
|
||||
"""
|
||||
|
||||
# Allow for pulling the algorithm off of the passed in jwk.
|
||||
if not algorithm and isinstance(key_data, dict):
|
||||
algorithm = key_data.get("alg", None)
|
||||
|
||||
if not algorithm:
|
||||
raise JWKError("Unable to find an algorithm for key: %s" % key_data)
|
||||
|
||||
key_class = get_key(algorithm)
|
||||
if not key_class:
|
||||
raise JWKError("Unable to find an algorithm for key: %s" % key_data)
|
||||
return key_class(key_data, algorithm)
|
||||
Reference in New Issue
Block a user