mirror of
https://github.com/TeamPGM/PagerMaid-Pyro.git
synced 2024-11-25 17:02:14 +00:00
35 lines
1.0 KiB
Python
35 lines
1.0 KiB
Python
import datetime
|
|
from typing import Optional
|
|
|
|
from fastapi import Header, HTTPException, Depends, Cookie
|
|
from jose import jwt
|
|
|
|
from pagermaid.config import Config
|
|
|
|
ALGORITHM = "HS256"
|
|
TOKEN_EXPIRE_MINUTES = 30
|
|
|
|
|
|
def authentication():
|
|
def inner(token: Optional[str] = Header(None), token_ck: str = Cookie(None)):
|
|
_token = token or token_ck
|
|
if Config.WEB_SECRET_KEY:
|
|
if _token == Config.WEB_SECRET_KEY:
|
|
return
|
|
try:
|
|
jwt.decode(_token, Config.WEB_SECRET_KEY, algorithms=ALGORITHM)
|
|
except (jwt.JWTError, jwt.ExpiredSignatureError, AttributeError):
|
|
raise HTTPException(
|
|
status_code=400, detail="登录验证失败或已失效,请重新登录"
|
|
)
|
|
|
|
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)
|