fix: use frozenset for SAFE_METHODS and extract SESSION_KEY constant
This commit is contained in:
parent
f93290d43e
commit
b5ea9950a2
1 changed files with 5 additions and 4 deletions
|
|
@ -10,7 +10,8 @@ from starlette.types import ASGIApp, Receive, Scope, Send
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
SAFE_METHODS = {"GET", "HEAD", "OPTIONS"}
|
SAFE_METHODS = frozenset({"GET", "HEAD", "OPTIONS"})
|
||||||
|
SESSION_KEY = "csrf_token"
|
||||||
|
|
||||||
|
|
||||||
def generate_csrf_token(request: Request) -> str:
|
def generate_csrf_token(request: Request) -> str:
|
||||||
|
|
@ -19,10 +20,10 @@ def generate_csrf_token(request: Request) -> str:
|
||||||
Stores the token at ``request.session["csrf_token"]``. Returns the
|
Stores the token at ``request.session["csrf_token"]``. Returns the
|
||||||
existing token when one is already present (idempotent per session).
|
existing token when one is already present (idempotent per session).
|
||||||
"""
|
"""
|
||||||
token: str | None = request.session.get("csrf_token")
|
token: str | None = request.session.get(SESSION_KEY)
|
||||||
if token is None:
|
if token is None:
|
||||||
token = secrets.token_urlsafe(32)
|
token = secrets.token_urlsafe(32)
|
||||||
request.session["csrf_token"] = token
|
request.session[SESSION_KEY] = token
|
||||||
return token
|
return token
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -70,7 +71,7 @@ class CSRFMiddleware:
|
||||||
return
|
return
|
||||||
|
|
||||||
# Token validation
|
# Token validation
|
||||||
expected_token: str | None = request.session.get("csrf_token")
|
expected_token: str | None = request.session.get(SESSION_KEY)
|
||||||
|
|
||||||
# Check header first, then fall back to form field
|
# Check header first, then fall back to form field
|
||||||
submitted_token: str | None = request.headers.get("x-csrf-token")
|
submitted_token: str | None = request.headers.get("x-csrf-token")
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue