B =@SaÎ6ã @sddlmZddlZddlmZddlmZddlmZddd d d d d gZ dZ e  d¡Z e  d¡Z e  dejejB¡ZdZdZdjeedZeedœZdddddddddg Zd Zd!d" d#d$„eDƒ¡d%Zd&ed'Zd(ed!ed)Zd*Ze  d+¡Ze  d,ed-¡Ze  d,ed-¡Ze  d,ed-¡Z e  d,edd.…d-¡Z!e  d/ed0¡Z"d1eeefZ#e  e#ejejB¡Z$e%d2ƒZ&e%d3ƒZ'e&e'Bd4hBZ(e(d5d6hBZ)e)d7hBZ*Z+Gd8d9„d9ed9e ƒƒZ,d:d;„Z-dKd=d>„Z.d?d@„Z/dAdB„Z0dCdD„Z1dEdF„Z2dGdH„Z3dIdJ„Z4dS)Lé)Úabsolute_importN)Ú namedtupleé)ÚLocationParseError)ÚsixÚschemeÚauthÚhostÚportÚpathÚqueryÚfragment)ÚhttpÚhttpsNz%[a-fA-F0-9]{2}z^(?:[a-zA-Z][a-zA-Z0-9+-]*:|/)zS^(?:([a-zA-Z][a-zA-Z0-9+.-]*):)?(?://([^\\/?#]*))?([^?#]*)(?:\?([^#]*))?(?:#(.*))?$z(?:[0-9]{1,3}\.){3}[0-9]{1,3}z[0-9A-Fa-f]{1,4}z(?:{hex}:{hex}|{ipv4}))ÚhexZipv4)rÚls32z(?:%(hex)s:){6}%(ls32)sz::(?:%(hex)s:){5}%(ls32)sz%(?:%(hex)s)?::(?:%(hex)s:){4}%(ls32)sz2(?:(?:%(hex)s:)?%(hex)s)?::(?:%(hex)s:){3}%(ls32)sz6(?:(?:%(hex)s:){0,2}%(hex)s)?::(?:%(hex)s:){2}%(ls32)sz/(?:(?:%(hex)s:){0,3}%(hex)s)?::%(hex)s:%(ls32)sz'(?:(?:%(hex)s:){0,4}%(hex)s)?::%(ls32)sz&(?:(?:%(hex)s:){0,5}%(hex)s)?::%(hex)sz(?:(?:%(hex)s:){0,6}%(hex)s)?::zDABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._!\-~z(?:ú|cCsg|] }|t‘qS©)Ú_subs)Ú.0Úxrrúh/private/var/folders/fg/1jzmct0d7d72tjkvm_1nhqc5sw67yj/T/pip-unpacked-wheel-uoovqmmx/urllib3/util/url.pyú 6srú)z (?:%25|%)(?:[z]|%[a-fA-F0-9]{2})+z\[z)?\]z!(?:[^\[\]%:/?#]|%[a-fA-F0-9]{2})*z!^(/[^?#]*)(?:\?([^#]*))?(?:#.*)?$ú^ú$éþÿÿÿú(z)\]$z^(%s|%s|%s)(?::([0-9]{0,5}))?$zBABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._-~z !$&'()*+,;=ú:ú@ú/ú?cs^eZdZdZdZd‡fdd„ Zedd„ƒZedd „ƒZed d „ƒZ ed d „ƒZ dd„Z ‡Z S)ÚUrlzÍ Data structure for representing an HTTP URL. Used as a return value for :func:`parse_url`. Both the scheme and host are normalized as they are both case-insensitive according to RFC 3986. rNc sD|r| d¡sd|}|dk r&| ¡}tt|ƒ ||||||||¡S)Nr )Ú startswithÚlowerÚsuperr"Ú__new__)Úclsrrr r r r r )Ú __class__rrr&[s  z Url.__new__cCs|jS)z@For backwards-compatibility with urlparse. We're nice like that.)r )ÚselfrrrÚhostnamemsz Url.hostnamecCs&|jpd}|jdk r"|d|j7}|S)z)Absolute path including the query string.r Nr!)r r )r)ÚurirrrÚ request_urirs  zUrl.request_uricCs|jrd|j|jfS|jS)z(Network location including host and portz%s:%d)r r )r)rrrÚnetloc|sz Url.netlocc Cs¢|\}}}}}}}d}|dk r*||d7}|dk r>||d7}|dk rN||7}|dk rf|dt|ƒ7}|dk rv||7}|dk rŠ|d|7}|dk rž|d|7}|S)aˆ Convert self into a url This function should more or less round-trip with :func:`.parse_url`. The returned url may not be exactly the same as the url inputted to :func:`.parse_url`, but it should be equivalent by the RFC (e.g., urls with a blank port will have : removed). Example: :: >>> U = parse_url('http://google.com/mail/') >>> U.url 'http://google.com/mail/' >>> Url('http', 'username:password', 'host.com', 80, ... '/path', 'query', 'fragment').url 'http://username:password@host.com:80/path?query#fragment' ÚNz://rrr!ú#)Ústr) r)rrr r r r r Úurlrrrr1ƒs"    zUrl.urlcCs|jS)N)r1)r)rrrÚ__str__«sz Url.__str__)NNNNNNN) Ú__name__Ú __module__Ú __qualname__Ú__doc__Ú __slots__r&Úpropertyr*r,r-r1r2Ú __classcell__rr)r(rr"Rs   (r"cCszd}d}x8|D]0}| |¡}|dkr&q|dks6||kr|}|}qW|dksR|dkr\|ddfS|d|…||dd…|fS)aì .. deprecated:: 1.25 Given a string and an iterable of delimiters, split on the first found delimiter. Return two split parts and the matched delimiter. If not found, then the first part is the full input string. Example:: >>> split_first('foo/bar?baz', '?/=') ('foo', 'bar?baz', '/') >>> split_first('foo/bar?baz', '123') ('foo/bar?baz', '', None) Scales linearly with number of delims. Not ideal for large number of delims. Nrr.é)Úfind)ÚsÚdelimsÚmin_idxÚ min_delimÚdÚidxrrrÚ split_first¯s   rBúutf-8c CsÖ|dkr |St |¡}t dd„|¡\}}| dd¡}|| d¡k}tƒ}x€tdt|ƒƒD]n}|||d…}t |ƒ} |r‚|dks–| d kr |  ¡|kr ||7}qZ|  dt | ƒd d… ¡  d ¡ ¡¡qZW|  |¡S) zfPercent-encodes a URI component without reapplying onto an already percent-encoded component. NcSs| d¡ ¡S)Nr)ÚgroupÚupper)ÚmatchrrrÚßóz'_encode_invalid_chars..zutf-8Ú surrogatepassó%rr:é€r)rÚ ensure_textÚ PERCENT_REÚsubnÚencodeÚcountÚ bytearrayÚrangeÚlenÚordÚdecodeÚextendrÚzfillrE) Ú componentÚ allowed_charsÚencodingÚpercent_encodingsÚ uri_bytesÚis_percent_encodedÚencoded_componentÚiÚbyteÚbyte_ordrrrÚ_encode_invalid_charsÒs"   ,rbcCsˆ| d¡}g}x8|D]0}|dkr$qq|dkr8| |¡q|r| ¡qW| d¡rj|r^|drj| dd¡| d¡r~| d¡d |¡S)Nr Ú.z..rr.)z/.z/..)ÚsplitÚappendÚpopr#ÚinsertÚendswithÚjoin)r ÚsegmentsÚoutputÚsegmentrrrÚ_remove_path_dot_segmentsôs       rmcCsê|ræt|tjƒrt |¡}|tkræt |¡}|r¼t |¡}|r²|  d¡\}}|||…}|  d¡rx|dkrx|dd…}n |dd…}dt |t ƒ}|d|…  ¡|||d…S|  ¡Sn*t |¡sæt d dd„| d¡Dƒ¡¡S|S) Nr:z%25éú%ó.cSsg|] }t|ƒ‘qSr)Ú _idna_encode)rÚlabelrrrr)sz#_normalize_host..rc)Ú isinstancerÚ binary_typeÚ ensure_strÚNORMALIZABLE_SCHEMESÚ IPV6_ADDRZ_RErFÚ ZONE_ID_REÚsearchÚspanr#rbÚUNRESERVED_CHARSr$ÚIPV4_RErird)r rÚis_ipv6rFÚstartÚendÚzone_idrrrÚ_normalize_hosts(         rcCs–|rˆtdd„|Dƒƒrˆy ddl}Wn$tk rFt tdƒd¡YnXy|j| ¡dddS|jk r†t td|ƒd¡YnX| ¡ d¡S) NcSsg|]}t|ƒdk‘qS)rK)rT)rrrrrr/sz _idna_encode..rz-Unable to parse URL without the 'idna' moduleT)ÚstrictÚ std3_rulesz#Name '%s' is not a valid IDNA labelÚascii) ÚanyÚidnaÚ ImportErrorrÚ raise_fromrrOr$Ú IDNAError)Únamer†rrrrq.s  rqcCs>t |¡ ¡\}}t|tƒ}t|tƒ}|dk r:|d|7}|S)zHPercent-encodes a request target so that there are no invalid charactersNr!)Ú TARGET_RErFÚgroupsrbÚ PATH_CHARSÚ QUERY_CHARS)Útargetr r rrrÚ_encode_target@s    rc sÚ|s tƒS|}t |¡s d|}yt |¡ ¡\}}}}}|dkpN| ¡tk}|r\| ¡}|rª| d¡\}} } |pvd}t  | ¡ ¡\} } |rœ|rœt |t ƒ}| dkr´d} n d\}} } | dk rât | ƒ} d| krØdksânt |ƒ‚t| |ƒ} |r |r t|ƒ}t |tƒ}|r |r t |tƒ}|r6|r6t |tƒ}Wn&ttfk r^t t |ƒd¡SX|s„|dk sz|dk r€d}nd}t|tjƒrštj‰ntj‰‡fdd „} t| |ƒ| |ƒ| | ƒ| | |ƒ| |ƒ| |ƒd S) a  Given a url, return a parsed :class:`.Url` namedtuple. Best-effort is performed to parse incomplete urls. Fields not provided will be None. This parser is RFC 3986 compliant. The parser logic and helper functions are based heavily on work done in the ``rfc3986`` module. :param str url: URL to parse into a :class:`.Url` namedtuple. Partly backwards-compatible with :mod:`urlparse`. Example:: >>> parse_url('http://google.com/mail/') Url(scheme='http', host='google.com', port=None, path='/mail/', ...) >>> parse_url('google.com:80') Url(scheme=None, host='google.com', port=80, path=None, ...) >>> parse_url('/foo?bar') Url(scheme=None, host=None, port=None, path='/foo', query='bar', ...) z//Nrr.)NNNriÿÿcs|dkr |Sˆ|ƒS)Nr)r)Ú ensure_funcrrÚ ensure_typeszparse_url..ensure_type)rrr r r r r )r"Ú SCHEME_REryÚURI_RErFrŒr$rvÚ rpartitionÚ _HOST_PORT_RErbÚUSERINFO_CHARSÚintrrrmrrŽÚFRAGMENT_CHARSÚ ValueErrorÚAttributeErrorrrˆrsÚ text_typerLru)r1Ú source_urlrÚ authorityr r r Ú normalize_urirÚ_Ú host_portr r r’r)r‘rÚ parse_urlJsb          r¢cCst|ƒ}|jpd|j|jfS)z4 Deprecated. Use :func:`parse_url` instead. r)r¢rr*r )r1ÚprrrÚget_host«sr¤)rC)5Ú __future__rÚreÚ collectionsrÚ exceptionsrÚpackagesrÚ url_attrsrvÚcompilerMr“ÚUNICODEÚDOTALLr”ÚIPV4_PATÚHEX_PATÚformatÚLS32_PATrÚ _variationsÚUNRESERVED_PATriÚIPV6_PATÚ ZONE_ID_PATÚIPV6_ADDRZ_PATÚ REG_NAME_PATr‹r|ÚIPV6_RErwÚBRACELESS_IPV6_ADDRZ_RErxZ_HOST_PORT_PATr–Úsetr{ÚSUB_DELIM_CHARSr—rrŽr™r"rBrbrmrrqrr¢r¤rrrrÚsn          ]# " a