[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@18.118.146.157: ~ $


�t�_�u�@s�dZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlm
Z
ddlmZddlmZddlmZddlmZdd	lmZmZmZmZmZmZmZmZmZmZm Z m!Z!m"Z"m#Z#dd
l$m%Z%ddl&m'Z'ddl(m)Z)m*Z*m+Z+m,Z,dlZ-ej.�Z/ddddiZ0ej1dkr�dd�Z2dd�Zdd�Z3dd�Z4ddd�Z5dd �Z6d!d"�Z7d#d$�Z8d%d&�Z9d'd(�Z:d)d*�Z;dd+d,�Z<d-d.�Z=d/d0�Z>d1d2�Z?d3d4�Z@d5d6�ZAd7d8�ZBd9d:�ZCd;d<�ZDeEd=d>�ZFd?d@�ZGdAdB�ZHdCdD�ZIdEdF�ZJdGdH�ZKdIdJ�ZLejMdKdL��ZNdMdN�ZOddOdP�ZPdQdR�ZQdSdTdU�ZRdVdW�ZSdXdY�ZTdZjUd[�ZVeVd\ZWeVd]ZXd^d_�ZYd`da�ZZdbdc�Z[ej\dd�Z]ej\de�Z^dfdg�Z_dhdi�Z`djdk�ZadS)mz�
requests.utils
~~~~~~~~~~~~~~

This module provides utility functions that are used within Requests
that are also useful for external consumption.
�N)�OrderedDict�)�__version__)�certs)�to_native_string)�parse_http_list)�quote�urlparse�bytes�str�unquote�
getproxies�proxy_bypass�
urlunparse�
basestring�
integer_types�is_py3�proxy_bypass_environment�getproxies_environment�Mapping)�cookiejar_from_dict)�CaseInsensitiveDict)�
InvalidURL�
InvalidHeader�FileModeWarning�UnrewindableBodyError�.netrc�_netrc�http�P�httpsi��win32cCsFy%trddl}nddl}Wntk
r=dSYnXyK|j|jd�}t|j|d�d�}|j|d�d}Wntk
r�dSYnX|s�|r�dS|j	d�}x||D]t}|dkr�d|kr�d	S|j
dd
�}|j
dd�}|j
d
d�}tj||tj
�r�d	Sq�WdS)NrFz;Software\Microsoft\Windows\CurrentVersion\Internet SettingsZProxyEnableZ
ProxyOverride�;z<local>�.Tz\.�*z.*�?)r�winreg�_winreg�ImportError�OpenKey�HKEY_CURRENT_USER�int�QueryValueEx�OSError�split�replace�re�match�I)�hostr&ZinternetSettingsZproxyEnableZ
proxyOverride�test�r5��/builddir/build/BUILDROOT/alt-python35-pip-20.2.4-1.el7.x86_64/opt/alt/python35/lib/python3.5/site-packages/pip/_vendor/requests/utils.py�proxy_bypass_registry0s8
			
	
r7cCs!t�rt|�St|�SdS)z�Return True, if the host should be bypassed.

        Checks proxy settings gathered from the environment, if specified,
        or the registry.
        N)rrr7)r3r5r5r6rWs	
rcCst|d�r|j�}|S)z/Returns an internal sequence dictionary update.�items)�hasattrr8)�dr5r5r6�dict_to_sequencecsr;cCs�d}d}t|d�r*t|�}n�t|d�rE|j}nht|d�r�y|j�}Wntjk
r{Yn2Xtj|�j}d|jkr�t	j
dt�t|d�rhy|j�}Wn*t
tfk
r�|dk	r�|}YnpXt|d�rh|dkrhy3|jdd	�|j�}|j|pBd�Wnt
tfk
rgd}YnX|dkrzd}td||�S)
Nr�__len__�len�fileno�ba%Requests has determined the content-length for this request using the binary size of the file: however, the file has been opened in text mode (i.e. without the 'b' flag in the mode). This may lead to an incorrect content-length. In Requests 3.0, support will be removed for files in text mode.�tell�seek�)r9r=r>�io�UnsupportedOperation�os�fstat�st_size�mode�warnings�warnrr@r-�IOErrorrA�max)�o�total_length�current_positionr>r5r5r6�	super_lenls@rPFcCsbyCddlm}m}d}x_tD]W}ytjjdj|��}Wntk
rcdSYnXtjj|�r&|}Pq&W|dkr�dSt	|�}d}t
|t�r�|jd�}|j
j|�d}	yG||�j|	�}
|
r|
drdnd}|
||
dfSWn!|tfk
rA|r=�YnXWnttfk
r]YnXdS)	z;Returns the Requests tuple auth for a given url from netrc.r)�netrc�NetrcParseErrorNz~/{}�:�asciirrB)rQrR�NETRC_FILESrE�path�
expanduser�format�KeyError�existsr	�
isinstancer�decode�netlocr.�authenticatorsrKr(�AttributeError)�url�raise_errorsrQrR�
netrc_path�f�loc�ri�splitstrr3r�login_ir5r5r6�get_netrc_auth�s8

	rhcCs[t|dd�}|rWt|t�rW|ddkrW|ddkrWtjj|�SdS)z0Tries to guess the filename of the given object.�nameNr�<r�>���)�getattrr[rrErV�basename)�objrir5r5r6�guess_filename�s%rpcCstjj|�r|Stjj|�\}}xJ|rztjj|�rztjj|�\}}dj||g�}q1Wtj|�s�|Stj|�}||j�kr�|St	j
�}tjj||jd��}tjj|�s|j|d|�}|S)z�Replace nonexistent paths that look like they refer to a member of a zip
    archive with the location of an extracted copy of the target, or else
    just return the provided path unchanged.
    �/rV)rErVrZr.�join�zipfile�
is_zipfile�ZipFile�namelist�tempfile�
gettempdir�extract)rV�archive�member�prefix�zip_file�tmp�extracted_pathr5r5r6�extract_zipped_paths�s r�cCsA|dkrdSt|ttttf�r7td��t|�S)aTake an object and test to see if it can be represented as a
    dictionary. Unless it can not be represented as such, return an
    OrderedDict, e.g.,

    ::

        >>> from_key_val_list([('key', 'val')])
        OrderedDict([('key', 'val')])
        >>> from_key_val_list('string')
        Traceback (most recent call last):
        ...
        ValueError: cannot encode objects that are not 2-tuples
        >>> from_key_val_list({'key': 'val'})
        OrderedDict([('key', 'val')])

    :rtype: OrderedDict
    Nz+cannot encode objects that are not 2-tuples)r[rr
�boolr+�
ValueErrorr)�valuer5r5r6�from_key_val_lists
r�cCs\|dkrdSt|ttttf�r7td��t|t�rR|j�}t|�S)a�Take an object and test to see if it can be represented as a
    dictionary. If it can be, return a list of tuples, e.g.,

    ::

        >>> to_key_val_list([('key', 'val')])
        [('key', 'val')]
        >>> to_key_val_list({'key': 'val'})
        [('key', 'val')]
        >>> to_key_val_list('string')
        Traceback (most recent call last):
        ...
        ValueError: cannot encode objects that are not 2-tuples

    :rtype: list
    Nz+cannot encode objects that are not 2-tuples)	r[rr
r�r+r�rr8�list)r�r5r5r6�to_key_val_listsr�cCstg}xgt|�D]Y}|dd�|dd�koDdknr_t|dd��}|j|�qW|S)aParse lists as described by RFC 2068 Section 2.

    In particular, parse comma-separated lists where the elements of
    the list may include quoted-strings.  A quoted-string could
    contain a comma.  A non-quoted string could have quotes in the
    middle.  Quotes are removed automatically after parsing.

    It basically works like :func:`parse_set_header` just that items
    may appear multiple times and case sensitivity is preserved.

    The return value is a standard :class:`list`:

    >>> parse_list_header('token, "quoted value"')
    ['token', 'quoted value']

    To create a header from the :class:`list` again, use the
    :func:`dump_header` function.

    :param value: a string with a list header.
    :return: :class:`list`
    :rtype: list
    Nr�"rlrl)�_parse_list_header�unquote_header_value�append)r��result�itemr5r5r6�parse_list_header=s0r�cCs�i}x�t|�D]�}d|kr2d||<q|jdd�\}}|dd�|dd�koudknr�t|dd��}|||<qW|S)a^Parse lists of key, value pairs as described by RFC 2068 Section 2 and
    convert them into a python dict:

    >>> d = parse_dict_header('foo="is a fish", bar="as well"')
    >>> type(d) is dict
    True
    >>> sorted(d.items())
    [('bar', 'as well'), ('foo', 'is a fish')]

    If there is no value for a key it will be `None`:

    >>> parse_dict_header('key_without_value')
    {'key_without_value': None}

    To create a header from the :class:`dict` again, use the
    :func:`dump_header` function.

    :param value: a string with a dict header.
    :return: :class:`dict`
    :rtype: dict
    �=Nrr�rlrl)r�r.r�)r�r�r�rir5r5r6�parse_dict_header]s
0r�cCsw|rs|d|d	ko%dknrs|dd
�}|sW|dd�dkrs|jdd�jdd�S|S)z�Unquotes a header value.  (Reversal of :func:`quote_header_value`).
    This does not use the real unquoting but what browsers are actually
    using for quoting.

    :param value: the header value to unquote.
    :rtype: str
    rrr�NrBz\\�\z\"rlrl)r/)r��is_filenamer5r5r6r��s
*r�cCs+i}x|D]}|j||j<q
W|S)z�Returns a key/value dictionary from a CookieJar.

    :param cj: CookieJar object to extract cookies from.
    :rtype: dict
    )r�ri)�cj�cookie_dict�cookier5r5r6�dict_from_cookiejar�s
r�cCs
t||�S)z�Returns a CookieJar from a key/value dictionary.

    :param cj: CookieJar to insert cookies into.
    :param cookie_dict: Dict of key/values to insert into CookieJar.
    :rtype: CookieJar
    )r)r�r�r5r5r6�add_dict_to_cookiejar�sr�cCsvtjdt�tjddtj�}tjddtj�}tjd�}|j|�|j|�|j|�S)zlReturns encodings from given content string.

    :param content: bytestring to extract encodings from.
    z�In requests 3.0, get_encodings_from_content will be removed. For more information, please see the discussion on issue #2266. (This warning should only appear once.)z!<meta.*?charset=["\']*(.+?)["\'>]�flagsz+<meta.*?content=["\']*;?charset=(.+?)["\'>]z$^<\?xml.*?encoding=["\']*(.+?)["\'>])rIrJ�DeprecationWarningr0�compiler2�findall)�content�
charset_re�	pragma_re�xml_rer5r5r6�get_encodings_from_content�sr�c
Cs�|jd�}|dj�|dd�}}i}d}x�|D]�}|j�}|rC|d}}|jd�}	|	dkr�|d|	�j|�}||	dd�j|�}|||j�<qCW||fS)	z�Returns content type and parameters from given header

    :param header: string
    :return: tuple containing content type and dictionary of
         parameters
    r"rrNz"' Tr�rl)r.�strip�find�lower)
�header�tokens�content_type�params�params_dict�items_to_strip�param�keyr��index_of_equalsr5r5r6�_parse_content_type_header�s!

r�cCs\|jd�}|sdSt|�\}}d|krH|djd�Sd|krXdSdS)z}Returns encodings from given HTTP Header Dict.

    :param headers: dictionary to extract encoding from.
    :rtype: str
    zcontent-typeN�charsetz'"�textz
ISO-8859-1)�getr�r�)�headersr�r�r5r5r6�get_encoding_from_headers�sr�ccs�|jdkr)x|D]}|VqWdStj|j�dd�}x(|D] }|j|�}|rK|VqKW|jddd�}|r�|VdS)zStream decodes a iterator.N�errorsr/��finalT)�encoding�codecs�getincrementaldecoderr\)�iterator�rr��decoder�chunk�rvr5r5r6�stream_decode_response_unicode�s
	
	r�ccsdd}|dks|dkr*t|�}x3|t|�kr_||||�V||7}q-WdS)z Iterate over slices of a string.rN)r=)�string�slice_length�posr5r5r6�iter_slicessr�cCs�tjdt�g}t|j�}|rayt|j|�SWntk
r`|j|�YnXyt|j|dd�SWnt	k
r�|jSYnXdS)z�Returns the requested content back in unicode.

    :param r: Response object to get unicode content from.

    Tried:

    1. charset from content-type
    2. fall back and replace all unicode characters

    :rtype: str
    z�In requests 3.0, get_unicode_from_response will be removed. For more information, please see the discussion on issue #2266. (This warning should only appear once.)r�r/N)
rIrJr�r�r�rr��UnicodeErrorr��	TypeError)r��tried_encodingsr�r5r5r6�get_unicode_from_responses

r�Z4ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzz0123456789-._~c
Cs�|jd�}x�tdt|��D]�}||dd�}t|�dkr�|j�r�ytt|d��}Wn"tk
r�td|��YnX|tkr�|||dd�||<q�d||||<q%d||||<q%Wdj	|�S)	z�Un-escape any percent-escape sequences in a URI that are unreserved
    characters. This leaves all reserved, illegal and non-ASCII bytes encoded.

    :rtype: str
    �%rrrB�z%Invalid percent-escape sequence: '%s'N�)
r.�ranger=�isalnum�chrr+r�r�UNRESERVED_SETrr)�uri�parts�i�h�cr5r5r6�unquote_unreserved:s
r�cCsOd}d}ytt|�d|�SWn"tk
rJt|d|�SYnXdS)z�Re-quote the given URI.

    This function passes the given URI through an unquote/quote cycle to
    ensure that it is fully and consistently quoted.

    :rtype: str
    z!#$%&'()*+,/:;=?@[]~z!#$&'()*+,/:;=?@[]~�safeN)rr�r)r��safe_with_percent�safe_without_percentr5r5r6�requote_uriRs
r�cCs�tjdtj|��d}|jd�\}}tjdtjtt|����d}tjdtj|��d|@}||@||@kS)z�This function allows you to check if an IP belongs to a network subnet

    Example: returns True if ip = 192.168.1.1 and net = 192.168.1.0/24
             returns False if ip = 192.168.1.1 and net = 192.168.100.0/24

    :rtype: bool
    z=Lrrq)�struct�unpack�socket�	inet_atonr.�dotted_netmaskr+)�ip�net�ipaddr�netaddr�bits�netmask�networkr5r5r6�address_in_networkhs
+#r�cCs/ddd|>dA}tjtjd|��S)z�Converts mask from /xx format to xxx.xxx.xxx.xxx

    Example: if mask is 24 function returns 255.255.255.0

    :rtype: str
    l��r� z>I)r��	inet_ntoar��pack)�maskr�r5r5r6r�wsr�cCs1ytj|�Wntjk
r,dSYnXdS)z
    :rtype: bool
    FT)r�r��error)�	string_ipr5r5r6�is_ipv4_address�s
	r�cCs�|jd�dkr�yt|jd�d�}Wntk
rJdSYnX|dksc|dkrgdSytj|jd�d�Wq�tjk
r�dSYq�XndSdS)zV
    Very simple check of the cidr format in no_proxy variable.

    :rtype: bool
    rqrFr�rT)�countr+r.r�r�r�r�)�string_networkr�r5r5r6�
is_valid_cidr�s
	r�ccsn|dk	}|r1tjj|�}|tj|<z	dVWd|ri|dkr\tj|=n
|tj|<XdS)z�Set the environment variable 'env_name' to 'value'

    Save previous value, yield, and then restore the previous value stored in
    the environment variable 'env_name'.

    If 'value' is None, do nothingN)rE�environr�)�env_namer��
value_changed�	old_valuer5r5r6�set_environ�s
	
r�c	Cs�dd�}|}|dkr*|d�}t|�}|jdkrIdS|r0dd�|jdd	�jd
�D�}t|j�r�x�|D]>}t|�r�t|j|�r�dSq�|j|kr�dSq�Wn^|j}|jr�|dj|j�7}x3|D]+}|jj	|�s(|j	|�rdSqWt
d|��<yt|j�}Wn!tt
jfk
rvd}YnXWdQRX|r�dSdS)
zL
    Returns whether we should bypass proxies or not.

    :rtype: bool
    cSs(tjj|�p'tjj|j��S)N)rEr�r��upper)�kr5r5r6�<lambda>�sz'should_bypass_proxies.<locals>.<lambda>N�no_proxyTcss|]}|r|VqdS)Nr5)�.0r3r5r5r6�	<genexpr>�sz(should_bypass_proxies.<locals>.<genexpr>� r��,z:{}F)r	�hostnamer/r.r�r�r��portrX�endswithr�rr�r��gaierror)	r`r��	get_proxy�no_proxy_arg�parsed�proxy_ip�host_with_portr3�bypassr5r5r6�should_bypass_proxies�s<(
		
!rcCs!t|d|�riSt�SdS)zA
    Return a dict of environment proxies.

    :rtype: dict
    r�N)rr
)r`r�r5r5r6�get_environ_proxies�srcCs�|p	i}t|�}|jdkrC|j|j|jd��S|jd|j|jd|jdg}d}x%|D]}||krz||}PqzW|S)z�Select a proxy for the url, if applicable.

    :param url: The url being for the request
    :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs
    N�allz://zall://)r	r�r��scheme)r`�proxies�urlparts�
proxy_keys�proxy�	proxy_keyr5r5r6�select_proxys
	

rzpython-requestscCsd|tfS)zO
    Return a string representing the default user agent.

    :rtype: str
    z%s/%s)r)rir5r5r6�default_user_agentsrc	Cs.tdt�ddjd
�dddd	i�S)z9
    :rtype: requests.structures.CaseInsensitiveDict
    z
User-AgentzAccept-Encodingz, �gzip�deflate�Acceptz*/*�
Connectionz
keep-alive)rr)rrrrr5r5r5r6�default_headers's
	rc	Csg}d}|j|�}|s%|Sx�tjd|�D]�}y|jdd�\}}Wntk
r{|d}}YnXd|jd�i}xb|jd�D]Q}y|jd�\}}Wntk
r�PYnX|j|�||j|�<q�W|j|�q8W|S)	z�Return a list of parsed link headers proxies.

    i.e. Link: <http:/.../front.jpeg>; rel=front; type="image/jpeg",<http://.../back.jpeg>; rel=back;type="image/jpeg"

    :rtype: list
    z '"z, *<r"rr�r`z<> '"r�)r�r0r.r�r�)	r��links�
replace_chars�valr`r��linkr�r�r5r5r6�parse_header_links3s&

 r�rTrB�cCs|dd�}|tjtjfkr,dS|dd�tjkrIdS|dd�tjtjfkrodS|jt�}|dkr�d	S|dkr�|ddd�tkr�d
S|ddd�tkr�dS|dkr|dd�t	kr�d
S|dd�t	krdSdS)z
    :rtype: str
    N�zutf-32rz	utf-8-sigrBzutf-16rzutf-8z	utf-16-berz	utf-16-lez	utf-32-bez	utf-32-le)
r��BOM_UTF32_LE�BOM_UTF32_BE�BOM_UTF8�BOM_UTF16_LE�BOM_UTF16_BEr��_null�_null2�_null3)�data�sample�	nullcountr5r5r6�guess_json_utf^s*"r(cCsPt||�\}}}}}}|s4||}}t||||||f�S)z�Given a URL that may or may not have a scheme, prepend the given scheme.
    Does not replace a present scheme with the one provided as an argument.

    :rtype: str
    )r	r)r`�
new_schemerr]rVr��query�fragmentr5r5r6�prepend_scheme_if_needed~s!
r,cCsSt|�}y"t|j�t|j�f}Wnttfk
rNd}YnX|S)z{Given a url with authentication components, extract them into a tuple of
    username,password.

    :rtype: (str,str)
    r�)r�r�)r	r�username�passwordr_r�)r`r�authr5r5r6�get_auth_from_url�s"r0s^\S[^\r\n]*$|^$z^\S[^\r\n]*$|^$cCs�|\}}t|t�r$t}nt}y#|j|�sLtd|��Wn1tk
r�td||t|�f��YnXdS)z�Verifies that header value is a string which doesn't contain
    leading whitespace or return characters. This prevents unintended
    header injection.

    :param header: tuple, in the format (name, value).
    z7Invalid return character or leading space in header: %sz>Value for header {%s: %s} must be of type str or bytes, not %sN)r[r
�_CLEAN_HEADER_REGEX_BYTE�_CLEAN_HEADER_REGEX_STRr1rr��type)r�rir��patr5r5r6�check_header_validity�s	
r5cCsct|�\}}}}}}|s1||}}|jdd�d}t|||||df�S)zW
    Given a url remove the fragment and the authentication part.

    :rtype: str
    �@rr�rl)r	�rsplitr)r`rr]rVr�r*r+r5r5r6�
urldefragauth�s

r8cCs~t|jdd�}|dk	rnt|jt�rny||j�Wqzttfk
rjtd��YqzXntd��dS)zfMove file pointer back to its recorded starting position
    so it can be read again on redirect.
    rANz;An error occurred when rewinding request body for redirect.z+Unable to rewind request body for redirect.)rm�bodyr[�_body_positionrrKr-r)�prepared_request�	body_seekr5r5r6�rewind_body�sr=)rr)b�__doc__r��
contextlibrCrEr0r�r��sysrwrIrs�collectionsrrr�r�_internal_utilsr�compatrr�rr	r
rrr
rrrrrrrr�cookiesr�
structuresr�
exceptionsrrrrrU�where�DEFAULT_CA_BUNDLE_PATH�
DEFAULT_PORTS�platformr7r;rPrhrpr�r�r�r�r�r�r�r�r�r�r�r�r�r��	frozensetr�r�r�r�r�r�r��contextmanagerr�rrrrrr�encoder"r#r$r(r,r0r�r1r2r5r8r=r5r5r5r6�<module>	s�^"'	=3  #
%
=	&

 

Filemanager

Name Type Size Permission Actions
__init__.cpython-35.pyc File 3.89 KB 0644
__version__.cpython-35.pyc File 606 B 0644
_internal_utils.cpython-35.pyc File 1.36 KB 0644
adapters.cpython-35.pyc File 17.49 KB 0644
api.cpython-35.pyc File 6.67 KB 0644
auth.cpython-35.pyc File 8.96 KB 0644
certs.cpython-35.pyc File 677 B 0644
compat.cpython-35.pyc File 1.78 KB 0644
cookies.cpython-35.pyc File 19.39 KB 0644
exceptions.cpython-35.pyc File 5.71 KB 0644
help.cpython-35.pyc File 2.91 KB 0644
hooks.cpython-35.pyc File 1.04 KB 0644
models.cpython-35.pyc File 25.55 KB 0644
packages.cpython-35.pyc File 595 B 0644
sessions.cpython-35.pyc File 20.35 KB 0644
status_codes.cpython-35.pyc File 5.1 KB 0644
structures.cpython-35.pyc File 4.5 KB 0644
utils.cpython-35.pyc File 23.34 KB 0644