o
    i'e[+                     @  s   d dl mZ d dlZd dlZd dlZd dlmZmZ ddlm	Z	m
Z
mZmZ ddlmZmZmZmZ ddlmZmZ ddlmZ erJdd	lmZmZ G d
d dZe ZejZejZejZejZejZejZej Z dS )    )annotationsN)TYPE_CHECKINGAny   )	Algorithmget_default_algorithms
has_cryptorequires_cryptography)DecodeErrorInvalidAlgorithmErrorInvalidSignatureErrorInvalidTokenError)base64url_decodebase64url_encode)RemovedInPyjwt3Warning)AllowedPrivateKeysAllowedPublicKeysc                   @  s   e Zd ZdZ		dHdId	d
ZedJddZdKddZdLddZdMddZ	dNddZ
					dOdPd+d,Z	-			dQdRd4d5Z	-			dQdSd7d8ZdTd9d:ZdUd<d=Z	-	dVdWdAdBZdXdCdDZdYdFdGZdS )ZPyJWSZJWTN
algorithmslist[str] | Noneoptionsdict[str, Any] | NonereturnNonec                 C  sl   t  | _|d urt|nt| j| _t| j D ]}|| jvr$| j|= q|d u r+i }i |  || _d S )N)r   _algorithmsset_valid_algslistkeys_get_default_optionsr   )selfr   r   key r"   +lib/python3.10/site-packages/jwt/api_jws.py__init__   s   
zPyJWS.__init__dict[str, bool]c                   C  s   ddiS )Nverify_signatureTr"   r"   r"   r"   r#   r   1   s   zPyJWS._get_default_optionsalg_idstralg_objr   c                 C  s>   || j v r	tdt|tstd|| j |< | j| dS )zW
        Registers a new Algorithm for use when creating and verifying tokens.
        z Algorithm already has a handler.z!Object is not of type `Algorithm`N)r   
ValueError
isinstancer   	TypeErrorr   add)r    r'   r)   r"   r"   r#   register_algorithm5   s   


zPyJWS.register_algorithmc                 C  s*   || j vr	td| j |= | j| dS )z
        Unregisters an Algorithm for use when creating and verifying tokens
        Throws KeyError if algorithm is not registered.
        zJThe specified algorithm could not be removed because it is not registered.N)r   KeyErrorr   remove)r    r'   r"   r"   r#   unregister_algorithmB   s   
zPyJWS.unregister_algorithm	list[str]c                 C  s
   t | jS )zM
        Returns a list of supported values for the 'alg' parameter.
        )r   r   )r    r"   r"   r#   get_algorithmsP   s   
zPyJWS.get_algorithmsalg_namec              
   C  sN   z| j | W S  ty& } zts|tv rtd| d|td|d}~ww )z
        For a given string name, return the matching Algorithm object.

        Example usage:

        >>> jws_obj.get_algorithm_by_name("RS256")
        zAlgorithm 'z9' could not be found. Do you have cryptography installed?Algorithm not supportedN)r   r/   r   r	   NotImplementedError)r    r4   er"   r"   r#   get_algorithm_by_nameV   s   

zPyJWS.get_algorithm_by_nameHS256FTpayloadbytesr!    AllowedPrivateKeys | str | bytes	algorithm
str | Noneheadersjson_encodertype[json.JSONEncoder] | Noneis_payload_detachedboolsort_headersc                 C  s*  g }|d ur|nd}	|r"| d}
|
r|d }	| d}|du r"d}| j|	d}|r4| | || |d s;|d= |rBd|d< nd|v rI|d= tj|d||d	 }|t| |r`|}nt|}|| d
	|}| 
|	}||}|||}|t| |rd|d< d
	|}|dS )NZnonealgb64FT)typrE   rG   ),:)Z
separatorsclsZ	sort_keys   .    r   utf-8)get
header_typ_validate_headersupdatejsondumpsencodeappendr   joinr8   prepare_keysigndecode)r    r:   r!   r=   r?   r@   rB   rD   segmentsZ
algorithm_Zheaders_algZheaders_b64headerZjson_headerZmsg_payloadsigning_inputr)   	signatureZencoded_stringr"   r"   r#   rT   g   sL   











zPyJWS.encode jwtstr | bytesAllowedPublicKeys | str | bytesdetached_payloadbytes | Nonedict[str, Any]c                 K  s   |rt dt|  t |d u ri }i | j|}|d }|r(|s(td| |\}	}
}}|dddu rP|d u rAtd|}	d	|

dd	d
 |	g}
|r[| |
|||| |	||dS )Nzypassing additional kwargs to decode_complete() is deprecated and will be removed in pyjwt version 3. Unsupported kwargs: r&   z\It is required that you pass in a value for the "algorithms" argument when calling decode().rF   TFzIt is required that you pass in a value for the "detached_payload" argument to decode a message having the b64 header set to false.rK   r   r   )r:   r[   r]   )warningswarntupler   r   r   r
   _loadrN   rV   rsplit_verify_signature)r    r_   r!   r   r   rb   kwargsZmerged_optionsr&   r:   r\   r[   r]   r"   r"   r#   decode_complete   s:   	
zPyJWS.decode_completer   c                 K  s:   |rt dt|  t | j|||||d}|d S )Nzppassing additional kwargs to decode() is deprecated and will be removed in pyjwt version 3. Unsupported kwargs: )rb   r:   )re   rf   rg   r   r   rl   )r    r_   r!   r   r   rb   rk   Zdecodedr"   r"   r#   rY      s   	

zPyJWS.decodec                 C  s   |  |d }| | |S )zReturns back the JWT header parameters as a dict()

        Note: The signature is not verified so the header parameters
        should not be fully trusted until signature verification is complete
           )rh   rP   )r    r_   r?   r"   r"   r#   get_unverified_header   s   
zPyJWS.get_unverified_header*tuple[bytes, bytes, dict[str, Any], bytes]c              
   C  sl  t |tr
|d}t |tstdt z|dd\}}|dd\}}W n ty9 } ztd|d }~ww zt|}W n t	t
jfyT } ztd|d }~ww zt|}W n typ }	 ztd|	 |	d }	~	ww t |tsztdzt|}
W n t	t
jfy } ztd	|d }~ww zt|}W n t	t
jfy } ztd
|d }~ww |
|||fS )NrM   z$Invalid token type. Token must be a rK   r   zNot enough segmentszInvalid header paddingzInvalid header string: z,Invalid header string: must be a json objectzInvalid payload paddingzInvalid crypto padding)r+   r(   rT   r;   r
   ri   splitr*   r   r,   binasciiErrorrR   loadsdict)r    r_   r\   Zcrypto_segmentZheader_segmentZpayload_segmenterrZheader_datar[   r7   r:   r]   r"   r"   r#   rh      sL   







zPyJWS._loadr\   r[   r]   c           
   
   C  s   z|d }W n t y   tdw |r|d ur ||vr tdz| |}W n ty8 } ztd|d }~ww ||}	|||	|sItdd S )NrE   zAlgorithm not specifiedz&The specified alg value is not allowedr5   zSignature verification failed)r/   r   r8   r6   rW   Zverifyr   )
r    r\   r[   r]   r!   r   rE   r)   r7   Zprepared_keyr"   r"   r#   rj     s"   

zPyJWS._verify_signaturec                 C  s   d|v r|  |d  d S d S )Nkid)_validate_kid)r    r?   r"   r"   r#   rP   8  s   zPyJWS._validate_headersrv   c                 C  s   t |ts	tdd S )Nz(Key ID header parameter must be a string)r+   r(   r   )r    rv   r"   r"   r#   rw   <  s   
zPyJWS._validate_kid)NN)r   r   r   r   r   r   )r   r%   )r'   r(   r)   r   r   r   )r'   r(   r   r   )r   r2   )r4   r(   r   r   )r9   NNFT)r:   r;   r!   r<   r=   r>   r?   r   r@   rA   rB   rC   rD   rC   r   r(   )r^   NNN)r_   r`   r!   ra   r   r   r   r   rb   rc   r   rd   )r_   r`   r!   ra   r   r   r   r   rb   rc   r   r   )r_   r`   r   rd   )r_   r`   r   ro   )r^   N)r\   r;   r[   rd   r]   r;   r!   ra   r   r   r   r   )r?   rd   r   r   )rv   r   r   r   )__name__
__module____qualname__rO   r$   staticmethodr   r.   r1   r3   r8   rT   rl   rY   rn   rh   rj   rP   rw   r"   r"   r"   r#   r      sD    



H0

+
r   )!Z
__future__r   rq   rR   re   typingr   r   r   r   r   r   r	   
exceptionsr
   r   r   r   Zutilsr   r   r   r   r   r   Z_jws_global_objrT   rl   rY   r.   r1   r8   rn   r"   r"   r"   r#   <module>   s,      (
