o
    …ªRhÔ  ã                   @   sh  d dl Z d dlZd dlZd dlmZmZ d dlmZ d dlm	Z	m
Z
 d dlmZ d dlmZmZmZmZmZmZ d dlmZmZmZ d dlZd dlmZmZ d d	lmZ d
dlm Z m!Z!m"Z"m#Z#m$Z$m%Z% d
dl&m'Z'm(Z( d
dl)m*Z*m+Z+m,Z,m-Z-m.Z.m/Z/ d
dl0m1Z1m2Z2m3Z3m4Z4m5Z5m6Z6m7Z7m8Z8m9Z9m:Z:m;Z;m<Z<m=Z= ddddddœZ>e?eƒZ@e?dƒZAe  Bde jC¡ZDedƒZEejFdkrÁd dlmGZG neZGG dd„ deƒZHeHjIZJG dd„ deƒZKG dd„ deddZLdeEd eEfd!d"„ZMe
d#eNd d$fd%d&„ƒZOe
d#eNd d$fd'd(„ƒZPe
d)eNd*eNd+eeNdf d,eeNdf d-eNd.eeQdf d/eNd0eNd1eNd d$fd2d3„ƒZRd)eNd4eNd/eNd5eNd1eNd d$fd6d7„ZSe
eSƒZTeMG d8d$„ d$ƒƒZUd9ZVd:ZWe
eVƒd;eNd eNfd<d=„ƒaXe
eVƒd-eNd eNfd>d?„ƒaYe
eWƒd-eNd@eZd eNfdAdB„ƒa[eMdOdCdD„ƒZ\eMd eKfdEdF„ƒZ]eMeVeVeJeJeJdGœdHeeQdf dIeeQdf dJeeQdeHf dKeeQdeHf dLeeQdeHf d dfdMdN„ƒZ^dS )Pé    N)ÚMappingÚSequence)ÚEnum)Ú
_CacheInfoÚ	lru_cache)Ú
ip_address)ÚTYPE_CHECKINGÚAnyÚ	TypedDictÚTypeVarÚUnionÚoverload)ÚSplitResultÚ	parse_qslÚuses_relative)Ú	MultiDictÚMultiDictProxy)Úunder_cached_propertyé   )ÚUSES_AUTHORITYÚSplitURLTypeÚmake_netlocÚsplit_netlocÚ	split_urlÚunsplit_result)Únormalize_pathÚnormalize_path_segments)ÚQueryÚQueryVariableÚSimpleQueryÚget_str_queryÚget_str_query_from_iterableÚ$get_str_query_from_sequence_iterable)ÚFRAGMENT_QUOTERÚFRAGMENT_REQUOTERÚPATH_QUOTERÚPATH_REQUOTERÚPATH_SAFE_UNQUOTERÚPATH_UNQUOTERÚQS_UNQUOTERÚQUERY_QUOTERÚQUERY_REQUOTERÚQUOTERÚREQUOTERÚUNQUOTERÚhuman_quoteéP   i»  é   )ÚhttpÚhttpsÚwsÚwssÚftpa<  
        # any character not in the unreserved or sub-delims sets, plus %
        # (validated with the additional check for pct-encoded sequences below)
        [^a-z0-9\-._~!$&'()*+,;=%]
    |
        # % only allowed if it is part of a pct-encoded
        # sequence of 2 hex digits.
        %(?![0-9a-f]{2})
    Ú_T)é   é   )ÚSelfc                   @   s   e Zd ZdZdZdS )ÚUndefinedTypez4Singleton type for use with not set sentinel values.r   N)Ú__name__Ú
__module__Ú__qualname__Ú__doc__Ú
_singleton© rA   rA   úK/home/air/sanwanet/backup_V2/venv/lib/python3.10/site-packages/yarl/_url.pyr;   P   s    r;   c                   @   s:   e Zd ZU dZeed< eed< eed< eed< eed< dS )Ú	CacheInfozHost encoding cache.Úidna_encodeÚidna_decoder   Úhost_validateÚencode_hostN)r<   r=   r>   r?   r   Ú__annotations__rA   rA   rA   rB   rC   Y   s   
 rC   c                   @   s¢  e Zd ZU eed< ded< eed< eed< eed< eed< eedf ed	< eedf ed
< eedf ed< eedf ed< eedf ed< eedf ed< eedf ed< eedf ed< eedf ed< eedf ed< eed< eed< e	e
eef  ed< ded< eed< eed< eed< eed< eed< eed< e
edf ed< e
edf ed < ded!< eed"< eed#< eed$< eed%< e
edf ed&< e
edf ed'< dS )(Ú_InternalURLCacheÚ_valÚURLÚ_originÚabsoluteÚschemeÚraw_authorityÚ	authorityNÚraw_userÚuserÚraw_passwordÚpasswordÚraw_hostÚhostÚhost_subcomponentÚhost_port_subcomponentÚportÚexplicit_portÚraw_pathÚpathÚ_parsed_queryúMultiDictProxy[str]ÚqueryÚraw_query_stringÚquery_stringÚpath_qsÚraw_path_qsÚraw_fragmentÚfragment.Ú	raw_partsÚpartsÚparentÚraw_nameÚnameÚ
raw_suffixÚsuffixÚraw_suffixesÚsuffixes)r<   r=   r>   r   rH   ÚboolÚstrr   ÚintÚlistÚtuplerA   rA   rA   rB   rI   c   sH   
 rI   F)ÚtotalÚobjÚreturnc                 C   s
   d| _ | S )NÚyarl)r=   )ru   rA   rA   rB   Úrewrite_module‰   s   rx   Úurl_strrK   c                 C   sÂ  i }t | ƒ\}}}}}|sd}n†d|v sd|v sd|v r%t|ƒ\}}	}}
nd } }	}
|}|du rA|tv r?d|› d}t|ƒ‚d}t|dd	}d|v rQ|d
d… n||d< |
|d< |	du rw|du rw|
du rg|n|› d|
› }d|d< d|d< n|r}t|ƒn|}|	r…t|	ƒn|	}t||||
ƒ}||d< ||d< |r¦t|ƒ}|r¦d|v r¦t|ƒ}|r¬t	|ƒ}|r²t
|ƒ}||d< |s¼|r¼dn||d< ||d< ||d< t t¡}||_||_||_||_||_||_|S )zParse unencoded URL.Ú ú:ú@ú[Nz9Invalid URL: host is required for absolute urls with the ú schemeF©Úvalidate_hostr   éÿÿÿÿrU   rZ   rQ   rS   Ú.rN   ú/r[   r`   rd   )r   r   ÚSCHEME_REQUIRES_HOSTÚ
ValueErrorÚ_encode_hostr-   r   r&   r   r+   r$   ÚobjectÚ__new__rK   Ú_schemeÚ_netlocÚ_pathÚ_queryÚ	_fragmentÚ_cache)ry   ÚcacherN   Únetlocr\   r_   re   rV   ÚusernamerT   rY   ÚmsgrQ   rS   ÚselfrA   rA   rB   Ú
encode_urlŽ   s`   ÿÿ

r”   c                 C   s4   t  t¡}t| ƒ}|\|_|_|_|_|_i |_	|S )zParse pre-encoded URL.)
r‡   rˆ   rK   r   r‰   rŠ   r‹   rŒ   r   rŽ   )ry   r“   ÚvalrA   rA   rB   Úpre_encoded_urlÎ   s
   
r–   rN   rP   rR   rT   rV   rY   r\   ra   re   c	           
      C   s    t  t¡}	| |	_|r||	_n4|r?|dur|t | ¡krdn|}|du r6|du r6|du r-|n|› d|› |	_nt||||ƒ|	_nd|	_||	_||	_	||	_
i |	_|	S )z#Build a pre-encoded URL from parts.Nr{   rz   )r‡   rˆ   rK   r‰   rŠ   ÚDEFAULT_PORTSÚgetr   r‹   rŒ   r   rŽ   )
rN   rP   rR   rT   rV   rY   r\   ra   re   r“   rA   rA   rB   Úbuild_pre_encoded_urlØ   s    
r™   r   r_   c                 C   s2   t  t¡}| |_||_||_||_||_i |_|S )zCreate a new URL from parts.)	r‡   rˆ   rK   r‰   rŠ   r‹   rŒ   r   rŽ   )rN   r   r\   r_   re   r“   rA   rA   rB   Úfrom_parts_uncachedù   s   
rš   c                   @   s   e Zd ZU dZeed< eed< eed< eed< eed< efddd	œd
eeed e	f de
dee
df dd fdd„Zeddddddddddddœdededeedf deedf dedeedf dedeedf dedede
dd fdd„ƒZdd„ Zdefd d!„Zdefd"d#„Zdefd$d%„Zd&ede
fd'd(„Zdefd)d*„Zd&ede
fd+d,„Zd&ede
fd-d.„Zd&ede
fd/d0„Zd&ede
fd1d2„Zd3edd fd4d5„Zdedd fd6d7„Zde
fd8d9„Zdee fd:d;„Z d<d=„ Z!dÆd>d?„Z"de
fd@dA„Z#de
fdBdC„Z$dÇdDdE„Z%e&de'fdFdG„ƒZ(e&dÇdHdI„ƒZ)dÇdJdK„Z*e&de
fdLdM„ƒZ+e&defdNdO„ƒZ,e&defdPdQ„ƒZ-e&defdRdS„ƒZ.e&deedf fdTdU„ƒZ/e&deedf fdVdW„ƒZ0e&deedf fdXdY„ƒZ1e&deedf fdZd[„ƒZ2e&deedf fd\d]„ƒZ3e&deedf fd^d_„ƒZ4e&deedf fd`da„ƒZ5e&deedf fdbdc„ƒZ6e&deedf fddde„ƒZ7e&deedf fdfdg„ƒZ8e&defdhdi„ƒZ9e&defdjdk„ƒZ:e&defdldm„ƒZ;e&de<eeef  fdndo„ƒZ=e&dÈdqdr„ƒZ>e&defdsdt„ƒZ?e&defdudv„ƒZ@e&defdwdx„ƒZAe&defdydz„ƒZBe&defd{d|„ƒZCe&defd}d~„ƒZDe&deedf fd€d„ƒZEe&deedf fd‚dƒ„ƒZFe&dÇd„d…„ƒZGe&defd†d‡„ƒZHe&defdˆd‰„ƒZIe&defdŠd‹„ƒZJe&defdŒd„ƒZKe&deedf fdŽd„ƒZLe&deedf fdd‘„ƒZMdÉd’d“de
dd fd”d•„ZNdedd fd–d—„ZOdeedf dd fd˜d™„ZPdeedf dd fdšd›„ZQdedd fdœd„ZRdeedf dd fdždŸ„ZSdddd œdede
d¡e
d¢e
dd f
d£d¤„ZTeUdedd fd¥d¦„ƒZVeUd§eWdd fd¨d¦„ƒZVd©eXd§eXdd fdªd¦„ZVeUdedd fd«d¬„ƒZYeUd§eWdd fd­d¬„ƒZYd©eXd§eXdd fd®d¬„ZYeUdedd fd¯d°„ƒZZeUd§eWdd fd±d°„ƒZZd©eXd§eXdd fd²d°„ZZd³edd fd´dµ„Z[deedf dd fd¶d·„Z\ddd¸œd3ed¡e
d¢e
dd fd¹dº„Z]ddd¸œd»ed¡e
d¢e
dd fd¼d½„Z^dÊd¿dÀ„Z_ddÁœd&ede
dd fdÂdÃ„Z`defdÄdÅ„ZadS )ËrK   )rŽ   r‰   rŠ   r‹   rŒ   r   r‰   rŠ   r‹   rŒ   r   FN)ÚencodedÚstrictr•   r›   rœ   rv   c                C   sÊ   |d ur	t  d¡ t|ƒtu r|rt|ƒS t|ƒS t|ƒ| u r!|S t|ƒtu r1|s-tdƒ‚t|Ž S t	|tƒrD|r>tt|ƒƒS tt|ƒƒS |t
u rat t¡}d |_ |_ |_ |_|_i |_|S tdƒ‚)Nzstrict parameter is ignoredz$Cannot apply decoding to SplitResultrz   z#Constructor parameter should be str)ÚwarningsÚwarnÚtyperp   r–   r”   r   r…   Ú
from_partsÚ
isinstanceÚ	UNDEFINEDr‡   rˆ   rK   r‰   rŠ   r‹   rŒ   r   rŽ   Ú	TypeError)Úclsr•   r›   rœ   r“   rA   rA   rB   rˆ   Y  s$   


zURL.__new__rz   )rN   rP   rR   rT   rV   rY   r\   r_   ra   re   r›   rN   rP   rR   rT   rV   rY   r\   r_   ra   re   c             
   C   sü  |r|s
|s
|s
|rt dƒ‚|dur!t|tƒs!tdt|ƒ›dƒ‚|r)|s)t dƒ‚|r1|	r1t dƒ‚|du sI|du sI|du sI|du sI|	du sI|
du rMtdƒ‚|rUt|ƒpTd}	|rct||||||||	|
ƒ	S t t	¡}||_
d}|r‚t|ƒ\}}}}|rt|d	d
nd}n|r‹t|dd
}nd|_|durÁ|dur¡|t |¡krŸdn|}|du r¸|du r¸|du r¯|n|› d|› |_n	t||||dƒ|_|rÇt|ƒn|}|râ|jrâd|v rÖt|ƒ}|d dkrâd}t |ƒ‚||_|sí|	rít|	ƒ}	|	|_|
röt|
ƒn|
|_i |_|S )zCreates and returns a new URLz@Can't mix "authority" with "user", "password", "host" or "port".Nz$The port is required to be int, got r‚   z/Can't build URL with "port" but without "host".z6Only one of "query" or "query_string" should be passedz}NoneType is illegal for "scheme", "authority", "host", "path", "query_string", and "fragment" args, use empty string instead.rz   Fr   Tr{   r   rƒ   zCPath in a URL with authority should start with a slash ('/') if set)r…   r¡   rq   r£   rŸ   r    r™   r‡   rˆ   rK   r‰   r   r†   rŠ   r—   r˜   r   r%   r   r‹   r*   rŒ   r#   r   rŽ   )r¤   rN   rP   rR   rT   rV   rY   r\   r_   ra   re   r›   r“   Ú_hostr’   rA   rA   rB   Úbuildv  s~   ÿÿ÷

ÿz	URL.buildc                 C   s   t d| ›dƒ‚)NzInheriting a class z from URL is forbidden)r£   )r¤   rA   rA   rB   Ú__init_subclass__Õ  ó   zURL.__init_subclass__c                 C   sx   | j s| jr| js| jrd}n| j }| j }d ur.|t | j¡kr.| j}t	| j
| j|d ƒ}n| j}t| j||| j| jƒS ©Nrƒ   )r‹   rŠ   rŒ   r   rZ   r—   r˜   r‰   rW   r   rQ   rS   r   )r“   r\   rY   rV   r   rA   rA   rB   Ú__str__Ø  s   ÿzURL.__str__c                 C   s   | j j› dt| ƒ› dS )Nz('z'))Ú	__class__r<   rp   ©r“   rA   rA   rB   Ú__repr__è  s   zURL.__repr__c                 C   s   t | ƒ d¡S )NÚascii)rp   Úencoder¬   rA   rA   rB   Ú	__bytes__ë  s   zURL.__bytes__Úotherc                 C   st   t |ƒturtS | js| jrdn| j}|js|jrdn|j}| j|jko9| j|jko9||ko9| j|jko9| j|jkS r©   )rŸ   rK   ÚNotImplementedr‹   rŠ   r‰   rŒ   r   )r“   r±   Úpath1Úpath2rA   rA   rB   Ú__eq__î  s   
ÿþ
ý
ûz
URL.__eq__c                 C   sR   | j  d¡ }d u r'| js| jrdn| j}t| j| j|| j| jfƒ }| j d< |S )NÚhashrƒ   )rŽ   r˜   r‹   rŠ   r¶   r‰   rŒ   r   )r“   Úretr\   rA   rA   rB   Ú__hash__ü  s   ÿzURL.__hash__c                 C   s   t |ƒturtS | j|jkS ©N©rŸ   rK   r²   rJ   ©r“   r±   rA   rA   rB   Ú__le__  ó   z
URL.__le__c                 C   s   t |ƒturtS | j|jk S r¹   rº   r»   rA   rA   rB   Ú__lt__	  r½   z
URL.__lt__c                 C   s   t |ƒturtS | j|jkS r¹   rº   r»   rA   rA   rB   Ú__ge__  r½   z
URL.__ge__c                 C   s   t |ƒturtS | j|jkS r¹   rº   r»   rA   rA   rB   Ú__gt__  r½   z
URL.__gt__rj   c                 C   s   t |tƒstS |  t|ƒf¡S r¹   )r¡   rp   r²   Ú_make_child©r“   rj   rA   rA   rB   Ú__truediv__  s   
zURL.__truediv__c                 C   s
   |   |¡S r¹   )Úupdate_query©r“   r_   rA   rA   rB   Ú__mod__  s   
zURL.__mod__c                 C   s   t | jp| jp| jp| jƒS r¹   )ro   rŠ   r‹   rŒ   r   r¬   rA   rA   rB   Ú__bool__   s   zURL.__bool__c                 C   s   t  t| j¡fS r¹   )rs   rˆ   r   rJ   r¬   rA   rA   rB   Ú__getstate__#  r¨   zURL.__getstate__c                 C   sR   |d d u rt |d tƒr|d d }n|^}}|\| _| _| _| _| _i | _d S )Nr   r   rJ   )r¡   Údictr‰   rŠ   r‹   rŒ   r   rŽ   )r“   Ústater•   ÚunusedrA   rA   rB   Ú__setstate__&  s
   
zURL.__setstate__c                 C   s0   | j }t| jƒ}|\|d< |d< |d< |d< dS )z"Cache the netloc parts of the URL.rQ   rS   rU   rZ   N)rŽ   r   rŠ   )r“   ÚcÚ	split_locrA   rA   rB   Ú_cache_netloc/  s   
 zURL._cache_netlocc                 C   ó   | j S )záA check for absolute URLs.

        Return True for absolute ones (having scheme or starting
        with //), False otherwise.

        Is is preferred to call the .absolute property instead
        as it is cached.
        )rM   r¬   rA   rA   rB   Úis_absolute5  s   	zURL.is_absolutec                 C   s(   | j  }du r| jdkS |t | j¡kS )zßA check for default port.

        Return True if port is default for specified scheme,
        e.g. 'http://python.org' or 'http://python.org:80', False
        otherwise.

        Return False for relative URLs.

        Nrz   )rZ   rŠ   r—   r˜   r‰   )r“   ÚexplicitrA   rA   rB   Úis_default_port@  s   

zURL.is_default_portc                 C   rÐ   )z}Return an URL with scheme, host and port parts only.

        user, password, path, query and fragment are removed.

        )rL   r¬   rA   rA   rB   ÚoriginQ  ó   z
URL.originc                 C   s   | j | j| j| j| jfS r¹   )r‰   rŠ   r‹   rŒ   r   r¬   rA   rA   rB   rJ   Z  s   zURL._valc                 C   sj   | j  }s	tdƒ‚| j }stdƒ‚d|v r"| j}tdd|| jƒ}n| js-| js-| js-| S t	||dddƒS )z|Return an URL with scheme, host and port parts only.

        user, password, path, query and fragment are removed.
        úURL should be absolutezURL should have schemer|   Nrz   )
rŠ   r…   r‰   rW   r   rZ   r‹   rŒ   r   r    )r“   r   rN   Úencoded_hostrA   rA   rB   rL   ^  s   

zURL._originc                 C   s$   | j stdƒ‚tdd| j| j| jƒS )zhReturn a relative part of the URL.

        scheme, user, password, host and port are removed.

        rÖ   rz   )rŠ   r…   r    r‹   rŒ   r   r¬   rA   rA   rB   Úrelativeo  s   zURL.relativec                 C   s
   | j dkS )z‰A check for absolute URLs.

        Return True for absolute ones (having scheme or starting
        with //), False otherwise.

        rz   ©rŠ   r¬   rA   rA   rB   rM   y  s   
zURL.absolutec                 C   rÐ   )zdScheme for absolute URLs.

        Empty string for relative URLs or URLs starting with //

        )r‰   r¬   rA   rA   rB   rN   ‡  rÕ   z
URL.schemec                 C   rÐ   )zQEncoded authority part of URL.

        Empty string for relative URLs.

        rÙ   r¬   rA   rA   rB   rO     rÕ   zURL.raw_authorityc                 C   s   t | j| j| j| jƒS )zQDecoded authority part of URL.

        Empty string for relative URLs.

        )r   rR   rT   rV   rY   r¬   rA   rA   rB   rP   ™  ó   zURL.authorityc                 C   ó   |   ¡  | jd S )zEEncoded user part of URL.

        None if user is missing.

        rQ   ©rÏ   rŽ   r¬   rA   rA   rB   rQ   ¢  s   
zURL.raw_userc                 C   ó   | j  }du r	dS t|ƒS )zEDecoded user part of URL.

        None if user is missing.

        N)rQ   r.   )r“   rQ   rA   rA   rB   rR   ­  ó   zURL.userc                 C   rÛ   )zMEncoded password part of URL.

        None if password is missing.

        rS   rÜ   r¬   rA   rA   rB   rS   ¸  ó   
zURL.raw_passwordc                 C   rÝ   )zMDecoded password part of URL.

        None if password is missing.

        N)rS   r.   )r“   rS   rA   rA   rB   rT   Â  rÞ   zURL.passwordc                 C   rÛ   )zÚEncoded host part of URL.

        None for relative URLs.

        When working with IPv6 addresses, use the `host_subcomponent` property instead
        as it will return the host subcomponent with brackets.
        rU   rÜ   r¬   rA   rA   rB   rU   Í  s   
zURL.raw_hostc                 C   s6   | j  }du r	dS |r|d  ¡ sd|v r|S t|ƒS )zDDecoded host part of URL.

        None for relative URLs.

        Nr   r{   )rU   ÚisdigitÚ_idna_decode©r“   ÚrawrA   rA   rB   rV   Û  s
   zURL.hostc                 C   s*   | j  }du r	dS d|v rd|› dS |S )aÑ  Return the host subcomponent part of URL.

        None for relative URLs.

        https://datatracker.ietf.org/doc/html/rfc3986#section-3.2.2

        `IP-literal = "[" ( IPv6address / IPvFuture  ) "]"`

        Examples:
        - `http://example.com:8080` -> `example.com`
        - `http://example.com:80` -> `example.com`
        - `https://127.0.0.1:8443` -> `127.0.0.1`
        - `https://[::1]:8443` -> `[::1]`
        - `http://[::1]` -> `[::1]`

        Nr{   r}   ú])rU   râ   rA   rA   rB   rW   é  s   zURL.host_subcomponentc                 C   s„   | j  }du r	dS |d dkr| d¡}| j}|du s#|t | j¡kr/d|v r-d|› dS |S d|v r;d|› d|› S |› d|› S )a  Return the host and port subcomponent part of URL.

        Trailing dots are removed from the host part.

        This value is suitable for use in the Host header of an HTTP request.

        None for relative URLs.

        https://datatracker.ietf.org/doc/html/rfc3986#section-3.2.2
        `IP-literal = "[" ( IPv6address / IPvFuture  ) "]"`
        https://datatracker.ietf.org/doc/html/rfc3986#section-3.2.3
        port        = *DIGIT

        Examples:
        - `http://example.com:8080` -> `example.com:8080`
        - `http://example.com:80` -> `example.com`
        - `http://example.com.:80` -> `example.com`
        - `https://127.0.0.1:8443` -> `127.0.0.1:8443`
        - `https://[::1]:8443` -> `[::1]:8443`
        - `http://[::1]` -> `[::1]`

        Nr   r‚   r{   r}   rä   z]:)rU   ÚrstriprZ   r—   r˜   r‰   )r“   rã   rY   rA   rA   rB   rX   ÿ  s   
&zURL.host_port_subcomponentc                 C   s   | j  }dur	|S t | j¡S )z«Port part of URL, with scheme-based fallback.

        None for relative URLs or URLs without explicit port and
        scheme without default port substitution.

        N)rZ   r—   r˜   r‰   )r“   rZ   rA   rA   rB   rY   %  s   zURL.portc                 C   rÛ   )zyPort part of URL, without scheme-based fallback.

        None for relative URLs or URLs without explicit port.

        rZ   rÜ   r¬   rA   rA   rB   rZ   1  rß   zURL.explicit_portc                 C   s   | j s| js	| j S dS )zNEncoded path of URL.

        / for absolute URLs without path part.

        rƒ   )r‹   rŠ   r¬   rA   rA   rB   r[   ;  rÚ   zURL.raw_pathc                 C   ó   | j rt| j ƒS | jrdS dS )zNDecoded path of URL.

        / for absolute URLs without path part.

        rƒ   rz   )r‹   r(   rŠ   r¬   rA   rA   rB   r\   D  s   zURL.pathc                 C   ræ   )z{Decoded path of URL.

        / for absolute URLs without path part.

        / (%2F) and % (%25) are not decoded

        rƒ   rz   )r‹   r'   rŠ   r¬   rA   rA   rB   Ú	path_safeM  s   	
zURL.path_safec                 C   s   t | jddS )zParse query part of URL.T©Úkeep_blank_values)r   rŒ   r¬   rA   rA   rB   r]   Z  s   zURL._parsed_queryr^   c                 C   s   t t| jƒƒS )z‘A MultiDictProxy representing parsed query parameters in decoded
        representation.

        Empty value if URL has no query part.

        )r   r   r]   r¬   rA   rA   rB   r_   _  s   z	URL.queryc                 C   rÐ   )zOEncoded query part of URL.

        Empty string if query is missing.

        )rŒ   r¬   rA   rA   rB   r`   i  rÕ   zURL.raw_query_stringc                 C   ó   | j rt| j ƒS dS )zODecoded query part of URL.

        Empty string if query is missing.

        rz   )rŒ   r)   r¬   rA   rA   rB   ra   r  ó   zURL.query_stringc                 C   s    | j  }s| jS | j› d|› S )zDecoded path of URL with query.ú?)ra   r\   ©r“   ÚqrA   rA   rB   rb   {  s    zURL.path_qsc                 C   sF   | j  }r| js| js| j› d|› S d|› S | js| js!| jS dS )zEncoded path of URL with query.rì   z/?rƒ   )rŒ   r‹   rŠ   rí   rA   rA   rB   rc   €  s   
&zURL.raw_path_qsc                 C   rÐ   )zUEncoded fragment part of URL.

        Empty string if fragment is missing.

        )r   r¬   rA   rA   rB   rd   ‡  rÕ   zURL.raw_fragmentc                 C   rê   )zUDecoded fragment part of URL.

        Empty string if fragment is missing.

        rz   )r   r.   r¬   rA   rA   rB   re     rë   zURL.fragment.c                 C   sf   | j }| jr|rdg|dd…  d¡¢R S dS |r,|d dkr,dg|dd…  d¡¢R S t| d¡ƒS )zjA tuple containing encoded *path* parts.

        ('/',) for absolute URLs if *path* is missing.

        rƒ   r   N)rƒ   r   )r‹   rŠ   Úsplitrs   )r“   r\   rA   rA   rB   rf   ™  s   "zURL.raw_partsc                 C   ó   t dd„ | jD ƒƒS )zjA tuple containing decoded *path* parts.

        ('/',) for absolute URLs if *path* is missing.

        c                 s   ó    | ]}t |ƒV  qd S r¹   ©r.   )Ú.0ÚpartrA   rA   rB   Ú	<genexpr>®  ó   € zURL.parts.<locals>.<genexpr>)rs   rf   r¬   rA   rA   rB   rg   §  rë   z	URL.partsc                 C   sb   | j }|r	|dkr| js| jrt| j| j|ddƒS | S | d¡}t| j| jd |dd… ¡ddƒS )z]A new URL with last part of path removed and cleaned up query and
        fragment.

        rƒ   rz   Nr   )r‹   r   rŒ   r    r‰   rŠ   rï   Újoin)r“   r\   rg   rA   rA   rB   rh   °  s   
"z
URL.parentc                 C   s0   | j }| js
|d S |dd… }|r|d S dS )zThe last part of raw_parts.r   r   Nrz   )rf   rŠ   )r“   rg   rA   rA   rB   ri   ¾  s
   zURL.raw_namec                 C   ó
   t | jƒS )zThe last part of parts.)r.   ri   r¬   rA   rA   rB   rj   Ç  s   
zURL.namec                 C   s@   | j }| d¡}d|  k rt|ƒd k rn n||d … S dS )Nr‚   r   r   rz   )ri   ÚrfindÚlen)r“   rj   ÚirA   rA   rB   rk   Ì  s   
0zURL.raw_suffixc                 C   rø   r¹   )r.   rk   r¬   rA   rA   rB   rl   Ò  s   
z
URL.suffixc                 C   s>   | j }| d¡r
dS | d¡}tdd„ | d¡dd … D ƒƒS )Nr‚   rA   c                 s   s    | ]}d | V  qdS )r‚   NrA   ©ró   rl   rA   rA   rB   rõ   Ü  rö   z#URL.raw_suffixes.<locals>.<genexpr>r   )ri   ÚendswithÚlstriprs   rï   rÂ   rA   rA   rB   rm   Ö  s
   

 zURL.raw_suffixesc                 C   rð   )Nc                 s   rñ   r¹   rò   rü   rA   rA   rB   rõ   à  rö   zURL.suffixes.<locals>.<genexpr>)rs   rm   r¬   rA   rA   rB   rn   Þ  s   zURL.suffixesÚpathszSequence[str]c                 C   sb  g }d}t t|ƒƒD ]A\}}|dk}|r"|d dkr"td|›dƒ‚|r&|nt|ƒ}|d|v O }| d¡}| ¡  ||sH|d dkrH|dd	… n|7 }q
| j }rn| d¡ }	rn|	d
 dkrd|	d	d
… n|	}
|
 ¡  ||
7 }| j }r€|r€|d
 dkr€| d¡ | ¡  |rˆ|s”t	| j
|d |¡ddƒS d t|ƒ¡}|r¨|d dkr¨d|› }t	| j
||ddƒS )z’
        add paths to self._path, accounting for absolute vs relative paths,
        keep existing, but do not create new, empty segments
        Fr   rƒ   zAppending path z! starting from slash is forbiddenr‚   rz   r   Nr   )Ú	enumerateÚreversedr…   r%   rï   Úreverser‹   rŠ   Úappendr    r‰   r÷   r   )r“   rÿ   r›   ÚparsedÚneeds_normalizeÚidxr\   ÚlastÚsegmentsÚold_segmentsÚoldr   rA   rA   rB   rÁ   â  s4   
ÿ
&

zURL._make_childc                 C   sV   t |tƒs	tdƒ‚| ¡ }| j}|s |tv r d|› d}t|ƒ‚t||| j| j	| j
ƒS )z&Return a new URL with scheme replaced.zInvalid scheme typez<scheme replacement is not allowed for relative URLs for the r~   )r¡   rp   r£   ÚlowerrŠ   r„   r…   r    r‹   rŒ   r   )r“   rN   Úlower_schemer   r’   rA   rA   rB   Úwith_scheme  s   
ÿÿzURL.with_schemec                 C   st   |du rd}nt |tƒrt|ƒ}| j}ntdƒ‚| j }s!tdƒ‚| jp%d}t|||| j	ƒ}t
| j|| j| j| jƒS )z€Return a new URL with user replaced.

        Autoencode user if needed.

        Clear user/password if user is None.

        NzInvalid user typez1user replacement is not allowed for relative URLsrz   )r¡   rp   r,   rS   r£   rŠ   r…   rW   r   rZ   r    r‰   r‹   rŒ   r   )r“   rR   rT   r   r×   rA   rA   rB   Ú	with_user   s   	


zURL.with_userc                 C   sp   |du rnt |tƒrt|ƒ}ntdƒ‚| j }stdƒ‚| jp d}| j}t| j	|||ƒ}t
| j|| j| j| jƒS )z‡Return a new URL with password replaced.

        Autoencode password if needed.

        Clear password if argument is None.

        NzInvalid password typez5password replacement is not allowed for relative URLsrz   )r¡   rp   r,   r£   rŠ   r…   rW   rZ   r   rQ   r    r‰   r‹   rŒ   r   )r“   rT   r   r×   rY   rA   rA   rB   Úwith_password6  s   	



zURL.with_passwordc                 C   st   t |tƒs	tdƒ‚| j }stdƒ‚|stdƒ‚|r t|ddnd}| j}t| j| j	||ƒ}t
| j|| j| j| jƒS )z¨Return a new URL with host replaced.

        Autoencode host if needed.

        Changing host for relative URLs is not allowed, use .join()
        instead.

        zInvalid host typez1host replacement is not allowed for relative URLszhost removing is not allowedTr   rz   )r¡   rp   r£   rŠ   r…   r†   rZ   r   rQ   rS   r    r‰   r‹   rŒ   r   )r“   rV   r   r×   rY   rA   rA   rB   Ú	with_hostL  s   


zURL.with_hostc                 C   s˜   |dur)t |tƒst |tƒstdt|ƒ› ƒ‚d|  kr!dks)n td|› ƒ‚| j }s2tdƒ‚| jp6d}t| j	| j
||ƒ}t| j|| j| j| jƒS )z`Return a new URL with port replaced.

        Clear port to default if None is passed.

        Nz port should be int or None, got r   iÿÿ  z&port must be between 0 and 65535, got z1port replacement is not allowed for relative URLsrz   )r¡   ro   rq   r£   rŸ   r…   rŠ   rW   r   rQ   rS   r    r‰   r‹   rŒ   r   )r“   rY   r   r×   rA   rA   rB   Ú	with_porta  s   

zURL.with_port)r›   Ú
keep_queryÚkeep_fragmentr  r  c                C   sr   | j }|st|ƒ}|rd|v rt|ƒn|}|r"|d dkr"d|› }|r'| jnd}|r.| jnd}t| j||||ƒS )z$Return a new URL with path replaced.r‚   r   rƒ   rz   )rŠ   r%   r   rŒ   r   r    r‰   )r“   r\   r›   r  r  r   r_   re   rA   rA   rB   Ú	with_paths  s   	
zURL.with_pathc                 C   ó   d S r¹   rA   rÅ   rA   rA   rB   Ú
with_query‡  ó   zURL.with_queryÚkwargsc                 K   r  r¹   rA   ©r“   r  rA   rA   rB   r  Š  r  Úargsc                 O   s*   t |i |¤Žpd}t| j| j| j|| jƒS )a[  Return a new URL with query part replaced.

        Accepts any Mapping (e.g. dict, multidict.MultiDict instances)
        or str, autoencode the argument if needed.

        A sequence of (key, value) pairs is supported as well.

        It also can take an arbitrary number of keyword arguments.

        Clear query if None is passed.

        rz   )r    rš   r‰   rŠ   r‹   r   )r“   r  r  r_   rA   rA   rB   r    s   ÿc                 C   r  r¹   rA   rÅ   rA   rA   rB   Úextend_query   r  zURL.extend_queryc                 K   r  r¹   rA   r  rA   rA   rB   r  £  r  c                 O   s\   t |i |¤Ž }s| S | j }r ||d dkr|nd|› 7 }n|}t| j| j| j|| jƒS )a&  Return a new URL with query part combined with the existing.

        This method will not remove existing query parameters.

        Example:
        >>> url = URL('http://example.com/?a=1&b=2')
        >>> url.extend_query(a=3, c=4)
        URL('http://example.com/?a=1&b=2&a=3&c=4')
        r   ú&)r    rŒ   rš   r‰   rŠ   r‹   r   )r“   r  r  Ú	new_queryr_   rA   rA   rB   r  ¦  s   

 ÿc                 C   r  r¹   rA   rÅ   rA   rA   rB   rÄ   ¼  r  zURL.update_queryc                 K   r  r¹   rA   r  rA   rA   rB   rÄ   ¿  r  c           	      O   s  |r|r
d}t |ƒ‚|}nt|ƒdkr|d }nt dƒ‚|du r#d}n^|s)| j}nXt|tƒr?t| jƒ}| |¡ t| 	¡ ƒ}nBt|t
ƒrYt| jƒ}| t|dd¡ t| 	¡ ƒ}n(t|tttfƒrgd}t|ƒ‚t|tƒr}t| jƒ}| |¡ t| 	¡ ƒ}ntd	ƒ‚t| j| j| j|| jƒS )
a  Return a new URL with query part updated.

        This method will overwrite existing query parameters.

        Example:
        >>> url = URL('http://example.com/?a=1&b=2')
        >>> url.update_query(a=3, c=4)
        URL('http://example.com/?a=3&b=2&c=4')
        z7Either kwargs or single query parameter must be presentr   r   Nrz   Trè   zAInvalid query type: bytes, bytearray and memoryview are forbiddenzRInvalid query type: only str, mapping or sequence of (key, value) pairs is allowed)r…   rú   rŒ   r¡   r   r   r]   Úupdater"   Úitemsrp   r   r!   ÚbytesÚ	bytearrayÚ
memoryviewr£   r   rš   r‰   rŠ   r‹   r   )	r“   r  r  r’   Úin_queryr_   ÚqmÚqstrÚqsrA   rA   rB   rÄ   Â  sB   








ÿÿÚquery_paramsc                    s<   t |ƒ| j ¡ @ ‰ ˆ s| S |  t‡ fdd„| j ¡ D ƒƒ¡S )z4Remove some keys from query part and return new URL.c                 3   s$    | ]\}}|ˆ vr||fV  qd S r¹   rA   )ró   rj   Úvalue©Úparams_to_removerA   rB   rõ   ý  s   € þýz+URL.without_query_params.<locals>.<genexpr>)Úsetr_   Úkeysr  rs   r  )r“   r'  rA   r)  rB   Úwithout_query_params÷  s   þÿzURL.without_query_paramsc                 C   sN   |du rd}nt |tƒstdƒ‚t|ƒ}| j|kr| S t| j| j| j| j	|ƒS )zReturn a new URL with fragment replaced.

        Autoencode fragment if needed.

        Clear fragment to default if None is passed.

        Nrz   zInvalid fragment type)
r¡   rp   r£   r#   r   r    r‰   rŠ   r‹   rŒ   )r“   re   rd   rA   rA   rB   Úwith_fragment  s   	

ÿzURL.with_fragment©r  r  c                C   sÈ   t |tƒs	tdƒ‚d|v rtdƒ‚t|ƒ}|dv rtdƒ‚t| jƒ}| j }r<t|ƒdkr3| 	|¡ n||d< d|d	< n||d< |d	 dkrJd|d	< |rO| j
nd}|rV| jnd}t| j|d |¡||ƒS )
z˜Return a new URL with name (last part of path) replaced.

        Query and fragment parts are cleaned up.

        Name is encoded if needed.

        zInvalid name typerƒ   zSlash in name is not allowed)r‚   z..z. and .. values are forbiddenr   r   rz   r   )r¡   rp   r£   r…   r%   rr   rf   rŠ   rú   r  rŒ   r   r    r‰   r÷   )r“   rj   r  r  rg   r   r_   re   rA   rA   rB   Ú	with_name  s&   



zURL.with_namerl   c                C   sˆ   t |tƒs	tdƒ‚|r|d dkr|dkrtd|›ƒ‚| j}|s(t| ›dƒ‚| j}|s1|| n
|dt|ƒ … | }| j|||dS )z Return a new URL with suffix (file extension of name) replaced.

        Query and fragment parts are cleaned up.

        suffix is encoded if needed.
        zInvalid suffix typer   r‚   zInvalid suffix z has an empty nameNr/  )r¡   rp   r£   r…   ri   rk   rú   r0  )r“   rl   r  r  rj   Ú
old_suffixrA   rA   rB   Úwith_suffix?  s   
"zURL.with_suffixÚurlc                 C   s4  t |ƒtur
tdƒ‚|jp| j}|| jks|tvr|S |j }r/|tv r/t|||j|j	|j
ƒS | j}|j }r||d dkr@|}n1|sHd|› }n)|d dkrU|› |› }nd g | jdd… ¢d‘¡| }|d dkrq|dd… }d|v ryt|ƒn|}n|}t|| j||sˆ|j	r‹|j	n| j	|s’|j
r–|j
ƒS | j
ƒS )	u_  Join URLs

        Construct a full (â€œabsoluteâ€) URL by combining a â€œbase URLâ€
        (self) with another URL (url).

        Informally, this uses components of the base URL, in
        particular the addressing scheme, the network location and
        (part of) the path, to provide missing components in the
        relative URL.

        zurl should be URLr   rƒ   r   Nrz   r   r‚   )rŸ   rK   r£   r‰   ÚUSES_RELATIVErŠ   r   r    r‹   rŒ   r   r÷   rg   r   )r“   r3  rN   Újoin_netlocÚ	orig_pathÚ	join_pathr\   rA   rA   rB   r÷   X  s:   
 ûûzURL.join©r›   c                G   s   | j ||dS )zAReturn a new URL with the elements in other appended to the path.r8  )rÁ   )r“   r›   r±   rA   rA   rB   ÚjoinpathŒ  s   zURL.joinpathc                 C   sª   t | jdƒ}t | jdƒ}| j }rd|v rd|› d}t | jdƒ}tr)|dus)J ‚d dd	„ | j ¡ D ƒ¡}t | j	d
ƒ}trD|dusDJ ‚t
|||| jƒ}t| j||||ƒS )z<Return decoded human readable string for URL representation.z#/:?@[]r{   r}   rä   z#?Nr  c                 s   s,    | ]\}}d   t|dƒt|dƒ¡V  qdS )z{}={}z#&+;=N)Úformatr/   )ró   ÚkÚvrA   rA   rB   rõ   ™  s
   € ÿ
ÿz!URL.human_repr.<locals>.<genexpr>rz   )r/   rR   rT   rV   r\   r   r÷   r_   r  re   r   rZ   r   r‰   )r“   rR   rT   rV   r\   ra   re   r   rA   rA   rB   Ú
human_repr  s   
þzURL.human_repr©rv   N)rv   rK   )rv   r^   )F)r3  rK   rv   rK   )br<   r=   r>   Ú	__slots__rp   rH   r¢   r   r   r;   ro   rˆ   Úclassmethodrq   r   r¦   r§   rª   r­   r   r°   r‡   rµ   r¸   r¼   r¾   r¿   rÀ   rÃ   rÆ   rÇ   rs   rÈ   rÌ   rÏ   rÑ   rÓ   rÔ   Úcached_propertyr   rJ   rL   rØ   rM   rN   rO   rP   rQ   rR   rS   rT   rU   rV   rW   rX   rY   rZ   r[   r\   rç   rr   r]   r_   r`   ra   rb   rc   rd   re   rf   rg   rh   ri   rj   rk   rl   rm   rn   rÁ   r  r  r  r  r  r  r   r  r   r	   r  rÄ   r-  r.  r0  r2  r÷   r9  r=  rA   rA   rA   rB   rK   
  s¦  
 Gþûþü
û
úóýü
û
úù
ø	÷

öõôóò^
	
	



	
%		/úþüûú
ù5ûþüû
ú*ûþüû
ú
4é   i   rã   c                 C   s6   z	t  |  d¡¡W S  ty   |  d¡ d¡ Y S w )Nr®   Úidna)rC  Údecoder¯   ÚUnicodeError)rã   rA   rA   rB   rá   ¨  s
   ÿrá   c                 C   s:   zt j| dd d¡W S  ty   |  d¡ d¡ Y S w )NT)Úuts46r®   rC  )rC  r¯   rD  rE  )rV   rA   rA   rB   Ú_idna_encode°  s
   ÿrG  r€   c           
   	   C   s  | rH| d   ¡ sd| v rH|  d¡\}}}zt|ƒ}W n	 ty#   Y n%w |j} |jdkr=|r7d| › d|› dS d| › dS |rF| › d|› S | S |  ¡ rŠ|  ¡ } |rˆt 	| ¡ }rˆ| 
¡ | ¡ d}}}	|dksu|dkrwd| |d	… v rwd
}	td| ›d|›d|› d|	› ƒd	‚| S t| ƒS )zEncode host part of URL.r   r{   ú%é   r}   rä   rz   r|   NzQ, if the value includes a username or password, use 'authority' instead of 'host'zHost z cannot contain z (at position ú))rà   Ú	partitionr   r…   Ú
compressedÚversionÚisasciir  ÚNOT_REG_NAMEÚsearchÚgroupÚstartrG  )
rV   r€   Úraw_ipÚsepÚzoneÚipÚinvalidr(  ÚposÚextrarA   rA   rB   r†   ¸  s2   ÿ
" ÿÿþr†   c                   C   s   t  ¡  t ¡  t ¡  dS )zClear all LRU caches.N)rG  Úcache_clearrá   r†   rA   rA   rA   rB   rZ  ò  s   rZ  c                   C   s$   t  ¡ t ¡ t ¡ t ¡ t ¡ dœS )zReport cache statistics.)rD   rE   r   rF   rG   )rG  Ú
cache_inforá   r†   rA   rA   rA   rB   r[  ú  s   ûr[  )Úidna_encode_sizeÚidna_decode_sizeÚip_address_sizeÚhost_validate_sizeÚencode_host_sizer\  r]  r^  r_  r`  c                 C   sØ   |t us|t urtjdtdd |durL||fD ]-}|du r!d}q|t u r,|t ur+|}q|t urEtr@t|tƒs9J ‚t|tƒs@J ‚t||ƒ}q|t u rLt}trUt|t	ƒrUJ ‚t
|ƒtjƒat
|ƒtjƒat
| ƒtjƒadS )zConfigure LRU cache sizes.z¬cache_configure() no longer accepts the ip_address_size or host_validate_size arguments, they are used to set the encode_host_size instead and will be removed in the futureé   )Ú
stacklevelN)r¢   r   rž   ÚDeprecationWarningr   r¡   rq   ÚmaxÚ_DEFAULT_ENCODE_SIZEr‡   r   r†   Ú__wrapped__rá   rG  )r\  r]  r^  r_  r`  ÚsizerA   rA   rB   Úcache_configure  s6   ú	€
€rh  r>  )_ÚreÚsysr   Úcollections.abcr   r   Úenumr   Ú	functoolsr   r   Ú	ipaddressr   Útypingr   r	   r
   r   r   r   Úurllib.parser   r   r   rC  Ú	multidictr   r   Úpropcache.apir   rA  Ú_parser   r   r   r   r   r   r‹   r   r   rŒ   r   r   r   r    r!   r"   Ú_quotersr#   r$   r%   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r—   Ú	frozensetr4  r„   ÚcompileÚVERBOSErO  r7   Úversion_infor:   r;   r@   r¢   rC   rI   rx   rp   r”   r–   rq   r™   rš   r    rK   Ú_DEFAULT_IDNA_SIZEre  rá   rG  ro   r†   rZ  r[  rh  rA   rA   rA   rB   Ú<module>   sä       <	ö

&?	ÿþ
ý
üû
úùø	÷
ö ÿÿÿÿÿ
þ         "9ú
þ
ýüûúù