PagerMaid-Pyro/pagermaid/web/api/utils.py

32 lines
926 B
Python
Raw Normal View History

2023-01-31 16:24:56 +00:00
import datetime
from typing import Optional
from fastapi import Header, HTTPException, Depends
from jose import jwt
from pagermaid.config import Config
2023-03-12 03:56:01 +00:00
ALGORITHM = "HS256"
2023-01-31 16:24:56 +00:00
TOKEN_EXPIRE_MINUTES = 30
def authentication():
def inner(token: Optional[str] = Header(...)):
if Config.WEB_SECRET_KEY:
2023-02-01 06:39:41 +00:00
if token == Config.WEB_SECRET_KEY:
return
try:
jwt.decode(token, Config.WEB_SECRET_KEY, algorithms=ALGORITHM)
except (jwt.JWTError, jwt.ExpiredSignatureError, AttributeError):
2023-03-12 03:56:01 +00:00
raise HTTPException(status_code=400, detail="登录验证失败或已失效,请重新登录")
2023-01-31 16:24:56 +00:00
return Depends(inner)
def create_token():
data = {
2023-03-12 03:56:01 +00:00
"exp": datetime.datetime.now(datetime.timezone.utc)
+ datetime.timedelta(minutes=TOKEN_EXPIRE_MINUTES),
2023-01-31 16:24:56 +00:00
}
return jwt.encode(data, Config.WEB_SECRET_KEY, algorithm=ALGORITHM)