????

Your IP : 216.73.216.233


Current Path : C:/opt/pgsql/pgAdmin 4/python/Lib/site-packages/authlib/oauth2/rfc7662/
Upload File :
Current File : C:/opt/pgsql/pgAdmin 4/python/Lib/site-packages/authlib/oauth2/rfc7662/token_validator.py

from ..rfc6749 import TokenValidator
from ..rfc6750 import (
    InvalidTokenError,
    InsufficientScopeError
)


class IntrospectTokenValidator(TokenValidator):
    TOKEN_TYPE = 'bearer'

    def introspect_token(self, token_string):
        """Request introspection token endpoint with the given token string,
        authorization server will return token information in JSON format.
        Developers MUST implement this method before using it::

            def introspect_token(self, token_string):
                # for example, introspection token endpoint has limited
                # internal IPs to access, so there is no need to add
                # authentication.
                url = 'https://example.com/oauth/introspect'
                resp = requests.post(url, data={'token': token_string})
                resp.raise_for_status()
                return resp.json()
        """
        raise NotImplementedError()

    def authenticate_token(self, token_string):
        return self.introspect_token(token_string)

    def validate_token(self, token, scopes, request):
        if not token or not token['active']:
            raise InvalidTokenError(realm=self.realm, extra_attributes=self.extra_attributes)
        if self.scope_insufficient(token.get('scope'), scopes):
            raise InsufficientScopeError()