HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: //snap/google-cloud-cli/396/lib/third_party/oauthlib/openid/connect/core/tokens.py
"""authlib.openid.connect.core.tokens ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

This module contains methods for adding JWT tokens to requests.
"""
from __future__ import absolute_import, unicode_literals

from oauthlib.oauth2.rfc6749.tokens import TokenBase, random_token_generator


class JWTToken(TokenBase):
  __slots__ = ('request_validator', 'token_generator',
               'refresh_token_generator', 'expires_in')

  def __init__(self,
               request_validator=None,
               token_generator=None,
               expires_in=None,
               refresh_token_generator=None):
    self.request_validator = request_validator
    self.token_generator = token_generator or random_token_generator
    self.refresh_token_generator = (
        refresh_token_generator or self.token_generator)
    self.expires_in = expires_in or 3600

  def create_token(self, request, refresh_token=False):
    """Create a JWT Token, using requestvalidator method."""

    if callable(self.expires_in):
      expires_in = self.expires_in(request)
    else:
      expires_in = self.expires_in

    request.expires_in = expires_in

    return self.request_validator.get_jwt_bearer_token(None, None, request)

  def validate_request(self, request):
    token = None
    if 'Authorization' in request.headers:
      token = request.headers.get('Authorization')[7:]
    else:
      token = request.access_token
    return self.request_validator.validate_jwt_bearer_token(
        token, request.scopes, request)

  def estimate_type(self, request):
    token = request.headers.get('Authorization', '')[7:]
    if token.startswith('ey') and token.count('.') in (2, 4):
      return 10
    else:
      return 0