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