[dashboard] Accept basic auth header

This commit is contained in:
Jesse Hills 2024-07-15 08:25:45 +12:00
parent 896af84acc
commit 59fe0323b1
No known key found for this signature in database
GPG key ID: BEAAE804EFD8E83A

View file

@ -107,6 +107,12 @@ def is_authenticated(handler: BaseHandler) -> bool:
return True
if settings.using_auth:
if auth_header := handler.request.headers.get("Authorization"):
assert isinstance(auth_header, str)
if auth_header.startswith("Basic "):
auth_decoded = base64.b64decode(auth_header[6:]).decode()
username, password = auth_decoded.split(":", 1)
return settings.check_password(username, password)
return handler.get_secure_cookie(AUTH_COOKIE_NAME) == COOKIE_AUTHENTICATED_YES
return True