o
    Df                     @   sJ   d dl mZ ddlmZmZ ddlmZ G dd dZG dd deZd	S )
    )add_params_to_qs   )client_secret_jwt_signprivate_key_jwt_sign)ASSERTION_TYPEc                   @   s2   e Zd ZdZdZdZdddZdd Zd	d
 ZdS )ClientSecretJWTao  Authentication method for OAuth 2.0 Client. This authentication
    method is called ``client_secret_jwt``, which is using ``client_id``
    and ``client_secret`` constructed with JWT to identify a client.

    Here is an example of use ``client_secret_jwt`` with Requests Session::

        from authlib.integrations.requests_client import OAuth2Session

        token_endpoint = 'https://example.com/oauth/token'
        session = OAuth2Session(
            'your-client-id', 'your-client-secret',
            token_endpoint_auth_method='client_secret_jwt'
        )
        session.register_client_auth_method(ClientSecretJWT(token_endpoint))
        session.fetch_token(token_endpoint)

    :param token_endpoint: A string URL of the token endpoint
    :param claims: Extra JWT claims
    :param headers: Extra JWT headers
    :param alg: ``alg`` value, default is HS256
    client_secret_jwtHS256Nc                 C   s(   || _ || _|| _|d ur|| _d S d S )N)token_endpointclaimsheadersalg)selfr
   r   r   r    r   T/home/ubuntu/webapp/venv/lib/python3.10/site-packages/authlib/oauth2/rfc7523/auth.py__init__   s   
zClientSecretJWT.__init__c                 C      t |j|j|| j| j| jdS N)	client_idr
   r   headerr   )r   client_secretr   r   r   r   r   authr
   r   r   r   sign&      zClientSecretJWT.signc                 C   s>   | j }|s|}| ||}t|pddtfd|fg}|||fS )N client_assertion_typeclient_assertion)r
   r   r   r   )r   r   methodurir   bodyr
   r   r   r   r   __call__0   s   
zClientSecretJWT.__call__)NNNN)	__name__
__module____qualname____doc__namer   r   r   r!   r   r   r   r   r      s    

r   c                   @   s    e Zd ZdZdZdZdd ZdS )PrivateKeyJWTaj  Authentication method for OAuth 2.0 Client. This authentication
    method is called ``private_key_jwt``, which is using ``client_id``
    and ``private_key`` constructed with JWT to identify a client.

    Here is an example of use ``private_key_jwt`` with Requests Session::

        from authlib.integrations.requests_client import OAuth2Session

        token_endpoint = 'https://example.com/oauth/token'
        session = OAuth2Session(
            'your-client-id', 'your-client-private-key',
            token_endpoint_auth_method='private_key_jwt'
        )
        session.register_client_auth_method(PrivateKeyJWT(token_endpoint))
        session.fetch_token(token_endpoint)

    :param token_endpoint: A string URL of the token endpoint
    :param claims: Extra JWT claims
    :param headers: Extra JWT headers
    :param alg: ``alg`` value, default is RS256
    private_key_jwtRS256c                 C   r   r   )r   r   r   r   r   r   r   r   r   r   r   V   r   zPrivateKeyJWT.signN)r"   r#   r$   r%   r&   r   r   r   r   r   r   r'   =   s
    r'   N)	authlib.common.urlsr   	assertionr   r   clientr   r   r'   r   r   r   r   <module>   s
    7