selfprivacy-rest-api/selfprivacy_api/graphql/__init__.py

36 lines
1.2 KiB
Python
Raw Normal View History

2022-06-24 17:08:58 +00:00
"""GraphQL API for SelfPrivacy."""
# pylint: disable=too-few-public-methods
import typing
2022-06-24 17:08:58 +00:00
from strawberry.permission import BasePermission
from strawberry.types import Info
from strawberry.extensions import Extension
2022-06-24 17:08:58 +00:00
from selfprivacy_api.actions.api_tokens import is_token_valid
from selfprivacy_api.utils.localization import Localization
2022-06-24 17:08:58 +00:00
2022-06-24 18:14:20 +00:00
2022-06-24 17:08:58 +00:00
class IsAuthenticated(BasePermission):
"""Is authenticated permission"""
2022-06-24 18:14:20 +00:00
2022-06-24 17:08:58 +00:00
message = "You must be authenticated to access this resource."
def has_permission(self, source: typing.Any, info: Info, **kwargs) -> bool:
token = info.context["request"].headers.get("Authorization")
if token is None:
token = info.context["request"].query_params.get("token")
if token is None:
2022-06-24 17:08:58 +00:00
return False
return is_token_valid(token.replace("Bearer ", ""))
class LocaleExtension(Extension):
"""Parse the Accept-Language header and set the locale in the context as one of the supported locales."""
def resolve(self, _next, root, info: Info, *args, **kwargs):
locale = Localization().get_locale(
info.context["request"].headers.get("Accept-Language")
)
info.context["locale"] = locale
return _next(root, info, *args, **kwargs)