Source code for auth_middleware.providers.authz.cognito_groups_provider

from typing import Any, Union

from auth_middleware.providers.authz.groups_provider import GroupsProvider
from auth_middleware.types.jwt import JWTAuthorizationCredentials


[docs] class CognitoGroupsProvider(GroupsProvider): """Recovers groups from AWS Cognito using the token provided Args: metaclass (_type_, optional): _description_. Defaults to ABCMeta. """
[docs] async def fetch_groups(self, token: Union[str, JWTAuthorizationCredentials]) -> list[str]: """Get groups using the token provided Args: token (JWTAuthorizationCredentials): _description_ Raises: NotImplementedError: _description_ Returns: List[str]: _description_ """ groups: list[str] = ( self.__get_groups_from_claims(token.claims) if isinstance(token, JWTAuthorizationCredentials) and ("cognito:groups" in token.claims or "scope" in token.claims) else [] ) return groups
def __get_groups_from_claims(self, claims: dict[str, Any]) -> list[str]: """Extracts groups from claims. Args: claims (dict): JWT claims. Returns: List[str]: List of groups. """ # cognito:groups is a list of groups # scope is only ONE scope return ( claims["cognito:groups"] if "cognito:groups" in claims else [str(claims["scope"]).split("/")[-1]] )