o
    Df+7                     @   s   d Z ddlZddlZddlZddlmZ ddlmZmZ ddl	m
Z
mZ dZdZd	Zd
ZdZdZd'ddZd'ddZdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& ZdS )(z
    authlib.oauth1.rfc5849.signature
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

    This module represents a direct implementation of `section 3.4`_ of the spec.

    .. _`section 3.4`: https://tools.ietf.org/html/rfc5849#section-3.4
    N)urlparse)
to_unicodeto_bytes   )escapeunescapez	HMAC-SHA1zRSA-SHA1	PLAINTEXTHEADERQUERYBODYc           	      C   sn   t ||}g }|D ]\}}|dv rq	|drt|}|||f q	t|}dt|  t|t|gS )aX  Generate signature base string from request, per `Section 3.4.1`_.

    For example, the HTTP request::

        POST /request?b5=%3D%253D&a3=a&c%40=&a2=r%20b HTTP/1.1
        Host: example.com
        Content-Type: application/x-www-form-urlencoded
        Authorization: OAuth realm="Example",
            oauth_consumer_key="9djdj82h48djs9d2",
            oauth_token="kkk9d7dh3k39sjv7",
            oauth_signature_method="HMAC-SHA1",
            oauth_timestamp="137131201",
            oauth_nonce="7d8f3e4a",
            oauth_signature="bYT5CMsGcbgUdFHObYMEfcx6bsw%3D"

        c2&a3=2+q

    is represented by the following signature base string (line breaks
    are for display purposes only)::

        POST&http%3A%2F%2Fexample.com%2Frequest&a2%3Dr%2520b%26a3%3D2%2520q
        %26a3%3Da%26b5%3D%253D%25253D%26c%2540%3D%26c2%3D%26oauth_consumer_
        key%3D9djdj82h48djs9d2%26oauth_nonce%3D7d8f3e4a%26oauth_signature_m
        ethod%3DHMAC-SHA1%26oauth_timestamp%3D137131201%26oauth_token%3Dkkk
        9d7dh3k39sjv7

    .. _`Section 3.4.1`: https://tools.ietf.org/html/rfc5849#section-3.4.1
    )oauth_signaturerealmoauth_&)normalize_base_string_uri
startswithr   appendnormalize_parametersjoinr   upper)	methoduriparamshostbase_string_uriunescaped_paramskvnormalized_params r   Y/home/ubuntu/webapp/venv/lib/python3.10/site-packages/authlib/oauth1/rfc5849/signature.pyconstruct_base_string   s   


r!   c           
      C   s   t | } t| \}}}}}}|r|std|sd}| }| }|dur+| }d}d|v rA|dd\}}	||	f|v rA|}t||||ddfS )a7  Normalize Base String URI per `Section 3.4.1.2`_.

    For example, the HTTP request::

        GET /r%20v/X?id=123 HTTP/1.1
        Host: EXAMPLE.COM:80

    is represented by the base string URI: "http://example.com/r%20v/X".

    In another example, the HTTPS request::

        GET /?q=1 HTTP/1.1
        Host: www.example.net:8080

    is represented by the base string URI: "https://www.example.net:8080/".

    .. _`Section 3.4.1.2`: https://tools.ietf.org/html/rfc5849#section-3.4.1.2

    The host argument overrides the netloc part of the uri argument.
    z$uri must include a scheme and netloc/N))http80)https443:r    )r   r   
ValueErrorlowersplit
urlunparse)
r   r   schemenetlocpathr   queryfragmentdefault_portsportr   r   r    r   Q   s    
r   c                 C   s.   dd | D }|   dd |D }d|S )a
  Normalize parameters per `Section 3.4.1.3.2`_.

    For example, the list of parameters from the previous section would
    be normalized as follows:

    Encoded::

    +------------------------+------------------+
    |          Name          |       Value      |
    +------------------------+------------------+
    |           b5           |     %3D%253D     |
    |           a3           |         a        |
    |          c%40          |                  |
    |           a2           |       r%20b      |
    |   oauth_consumer_key   | 9djdj82h48djs9d2 |
    |       oauth_token      | kkk9d7dh3k39sjv7 |
    | oauth_signature_method |     HMAC-SHA1    |
    |     oauth_timestamp    |     137131201    |
    |       oauth_nonce      |     7d8f3e4a     |
    |           c2           |                  |
    |           a3           |       2%20q      |
    +------------------------+------------------+

    Sorted::

    +------------------------+------------------+
    |          Name          |       Value      |
    +------------------------+------------------+
    |           a2           |       r%20b      |
    |           a3           |       2%20q      |
    |           a3           |         a        |
    |           b5           |     %3D%253D     |
    |          c%40          |                  |
    |           c2           |                  |
    |   oauth_consumer_key   | 9djdj82h48djs9d2 |
    |       oauth_nonce      |     7d8f3e4a     |
    | oauth_signature_method |     HMAC-SHA1    |
    |     oauth_timestamp    |     137131201    |
    |       oauth_token      | kkk9d7dh3k39sjv7 |
    +------------------------+------------------+

    Concatenated Pairs::

    +-------------------------------------+
    |              Name=Value             |
    +-------------------------------------+
    |               a2=r%20b              |
    |               a3=2%20q              |
    |                 a3=a                |
    |             b5=%3D%253D             |
    |                c%40=                |
    |                 c2=                 |
    | oauth_consumer_key=9djdj82h48djs9d2 |
    |         oauth_nonce=7d8f3e4a        |
    |   oauth_signature_method=HMAC-SHA1  |
    |      oauth_timestamp=137131201      |
    |     oauth_token=kkk9d7dh3k39sjv7    |
    +-------------------------------------+

    and concatenated together into a single string (line breaks are for
    display purposes only)::

        a2=r%20b&a3=2%20q&a3=a&b5=%3D%253D&c%40=&c2=&oauth_consumer_key=9dj
        dj82h48djs9d2&oauth_nonce=7d8f3e4a&oauth_signature_method=HMAC-SHA1
        &oauth_timestamp=137131201&oauth_token=kkk9d7dh3k39sjv7

    .. _`Section 3.4.1.3.2`: https://tools.ietf.org/html/rfc5849#section-3.4.1.3.2
    c                 S   s    g | ]\}}t |t |fqS r   r   .0r   r   r   r   r    
<listcomp>   s     z(normalize_parameters.<locals>.<listcomp>c                 S   s   g | ]\}}| d | qS )=r   r5   r   r   r    r7      s    r   )sortr   )r   
key_valuesparameter_partsr   r   r    r      s   J
r   c                 C   s"   | j dd}t| j| j| j|S )z,Generate signature base string from request.HostN)headersgetr!   r   r   r   )requestr   r   r   r    generate_signature_base_string   s   r@   c                 C   s^   | }t |pd}|d7 }|t |pd7 }tt|t|tj}t| dd }t	|S )aZ  Generate signature via HMAC-SHA1 method, per `Section 3.4.2`_.

    The "HMAC-SHA1" signature method uses the HMAC-SHA1 signature
    algorithm as defined in `RFC2104`_::

        digest = HMAC-SHA1 (key, text)

    .. _`RFC2104`: https://tools.ietf.org/html/rfc2104
    .. _`Section 3.4.2`: https://tools.ietf.org/html/rfc5849#section-3.4.2
    r(   r   N)
r   hmacnewr   hashlibsha1binascii
b2a_base64digestr   )base_stringclient_secrettoken_secrettextkey	signaturesigr   r   r    hmac_sha1_signature   s   rP   c                 C   s<   ddl m} t| } |t| |}t|dd }t|S )ar  Generate signature via RSA-SHA1 method, per `Section 3.4.3`_.

    The "RSA-SHA1" signature method uses the RSASSA-PKCS1-v1_5 signature
    algorithm as defined in `RFC3447, Section 8.2`_ (also known as
    PKCS#1), using SHA-1 as the hash function for EMSA-PKCS1-v1_5.  To
    use this method, the client MUST have established client credentials
    with the server that included its RSA public key (in a manner that is
    beyond the scope of this specification).

    .. _`Section 3.4.3`: https://tools.ietf.org/html/rfc5849#section-3.4.3
    .. _`RFC3447, Section 8.2`: https://tools.ietf.org/html/rfc3447#section-8.2
    r   )	sign_sha1NrA   )rsarQ   r   rF   rG   r   )rI   rsa_private_keyrQ   srO   r   r   r    rsa_sha1_signature)  s
   rU   c                 C   s(   t | pd}|d7 }|t |pd7 }|S )a  Generate signature via PLAINTEXT method, per `Section 3.4.4`_.

    The "PLAINTEXT" method does not employ a signature algorithm.  It
    MUST be used with a transport-layer mechanism such as TLS or SSL (or
    sent over a secure channel with equivalent protections).  It does not
    utilize the signature base string or the "oauth_timestamp" and
    "oauth_nonce" parameters.

    .. _`Section 3.4.4`: https://tools.ietf.org/html/rfc5849#section-3.4.4
    r(   r   r4   )rJ   rK   rN   r   r   r    plaintext_signature=  s   rV   c                 C   s   t |}t|| j| jS )zSign a HMAC-SHA1 signature.)r@   rP   rJ   rK   clientr?   rI   r   r   r    sign_hmac_sha1]  s   
rY   c                 C   s   t |}t|| jS )z4Sign a RSASSA-PKCS #1 v1.5 base64 encoded signature.)r@   rU   rsa_keyrW   r   r   r    sign_rsa_sha1d  s   r[   c                 C   s   t | j| jS )zSign a PLAINTEXT signature.)rV   rJ   rK   )rX   r?   r   r   r    sign_plaintextj  s   r\   c                 C   s&   t | }t|| j| j}t|| jS )zVerify a HMAC-SHA1 signature.)r@   rP   rJ   rK   rB   compare_digestrN   )r?   rI   rO   r   r   r    verify_hmac_sha1o  s
   
r^   c                 C   s6   ddl m} t| }tt| j}||t|| jS )z6Verify a RSASSA-PKCS #1 v1.5 base64 encoded signature.r   )verify_sha1)rR   r_   r@   rF   
a2b_base64r   rN   rsa_public_key)r?   r_   rI   rO   r   r   r    verify_rsa_sha1w  s   rb   c                 C   s   t | j| j}t|| jS )zVerify a PLAINTEXT signature.)rV   rJ   rK   rB   r]   rN   )r?   rO   r   r   r    verify_plaintext  s   rc   )N)__doc__rF   rD   rB   authlib.common.urlsr   authlib.common.encodingr   r   utilr   r   SIGNATURE_HMAC_SHA1SIGNATURE_RSA_SHA1SIGNATURE_PLAINTEXTSIGNATURE_TYPE_HEADERSIGNATURE_TYPE_QUERYSIGNATURE_TYPE_BODYr!   r   r   r@   rP   rU   rV   rY   r[   r\   r^   rb   rc   r   r   r   r    <module>   s4    

8G\. 