CasperSecurity

Current Path : /lib/python3/dist-packages/requests/__pycache__/
Upload File :
Current File : //lib/python3/dist-packages/requests/__pycache__/utils.cpython-310.pyc

o

��Hh2v�@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,d
Z-e�.�Z/ddd�Z0ej1dkr�dd�Z2dd�Zdd�Z3dd�Z4didd�Z5dd�Z6dd �Z7d!d"�Z8d#d$�Z9d%d&�Z:d'd(�Z;did)d*�Z<d+d,�Z=d-d.�Z>d/d0�Z?d1d2�Z@d3d4�ZAd5d6�ZBd7d8�ZCd9d:�ZDeEd;�ZFd<d=�ZGd>d?�ZHd@dA�ZIdBdC�ZJdDdE�ZKdFdG�ZLejMdHdI��ZNdJdK�ZOdjdLdM�ZPdNdO�ZQdkdQdR�ZRdSdT�ZSdUdV�ZTdW�UdX�ZVeVdYZWeVdZZXd[d\�ZYd]d^�ZZd_d`�Z[e�\da�Z]e�\db�Z^dcdd�Z_dedf�Z`dgdh�ZadS)lz�
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)z.netrc�_netrc�Pi�)�http�https�win32cCs�z
trddl}nddl}Wn
tyYdSwz|�|jd�}t|�|d�d�}|�|d�d}Wn
ty=YdSw|rB|sDdS|�	d�}|D]*}|dkrXd|vrXd	S|�
dd
�}|�
dd�}|�
d
d�}t�||tj
�rud	SqKdS)NrFz;Software\Microsoft\Windows\CurrentVersion\Internet Settings�ProxyEnable�
ProxyOverride�;z<local>�.Tz\.�*z.*�?)r�winreg�_winreg�ImportError�OpenKey�HKEY_CURRENT_USER�int�QueryValueEx�OSError�split�replace�re�match�I)�hostr)�internetSettings�proxyEnable�
proxyOverride�test�r;�0/usr/lib/python3/dist-packages/requests/utils.py�proxy_bypass_registry0sN
��������
�r=cCst�rt|�St|�S)z�Return True, if the host should be bypassed.

        Checks proxy settings gathered from the environment, if specified,
        or the registry.
        )rrr=)r6r;r;r<rWsrcCst|d�r	|��}|S)z/Returns an internal sequence dictionary update.�items)�hasattrr>)�dr;r;r<�dict_to_sequencecs
rAc	Cs$d}d}t|d�rt|�}n0t|d�r|j}n't|d�r>z|��}Wn
tjy,Ynwt�|�j}d|jvr>t	�
dt�t|d�r�z|��}Wnt
tfyZ|durX|}Yn+wt|d�r�|dur�z|�dd	�|��}|�|ptd�Wn
t
tfy�d}Ynw|dur�d}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�)r?rCrD�io�UnsupportedOperation�os�fstat�st_size�mode�warnings�warnrrFr0�IOErrorrG�max)�o�total_length�current_positionrDr;r;r<�	super_lenlsJ



�
�

���rVFc
	Cstj�d�}|dur|f}ndd�tD�}zlddlm}m}d}|D]!}ztj�|�}Wnty8YWdSwtj�	|�rC|}nq"|durKWdSt
|�}	|	j}
z||��|
�}|rn|drbdnd}|||dfWWSWWdS|t
fy�|r}�YWdSwttfy�YdSw)	z;Returns the Requests tuple auth for a given url from netrc.�NETRCNcss�|]}d�|�VqdS)z~/{}N)�format)�.0�fr;r;r<�	<genexpr>�s�z!get_netrc_auth.<locals>.<genexpr>r)�netrc�NetrcParseErrorrrH)rK�environ�get�NETRC_FILESr\r]�path�
expanduser�KeyError�existsr
�hostname�authenticatorsrQr+�AttributeError)
�url�raise_errors�
netrc_file�netrc_locationsr\r]�
netrc_pathrZ�loc�rir6r�login_ir;r;r<�get_netrc_auth�sF
������rpcCsNt|dd�}|rt|t�r!|ddkr#|ddkr%tj�|�SdSdSdSdS)z0Tries to guess the filename of the given object.�nameNr�<����>)�getattr�
isinstancerrKra�basename)�objrqr;r;r<�guess_filename�s�rycCs�tj�|�r|Stj�|�\}}|r/tj�|�s/tj�|�\}}d�||g�}|r/tj�|�rt�|�s6|St�|�}||��vrC|St	�
�}tjj|g|�d��R�}tj�|�sa|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.
    �/)ra)rKrardr1�join�zipfile�
is_zipfile�ZipFile�namelist�tempfile�
gettempdir�extract)ra�archive�member�prefix�zip_file�tmp�extracted_pathr;r;r<�extract_zipped_paths�s"�

r�cCs.|durdSt|ttttf�rtd��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
    N�+cannot encode objects that are not 2-tuples)rvrr�boolr.�
ValueErrorr��valuer;r;r<�from_key_val_lists
r�cCs@|durdSt|ttttf�rtd��t|t�r|��}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
    Nr�)	rvrrr�r.r�rr>�listr�r;r;r<�to_key_val_lists
r�cCsXg}t|�D]#}|dd�|dd�krdkr$nnt|dd��}|�|�q|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
    Nrrs�")�_parse_list_header�unquote_header_value�append)r��result�itemr;r;r<�parse_list_header=s(r�cCsxi}t|�D]3}d|vrd||<q|�dd�\}}|dd�|dd�kr+dkr5nnt|dd��}|||<q|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
    �=Nrrsr�)r�r1r�)r�r�r�rqr;r;r<�parse_dict_header]s(
r�cCs^|r-|d|dkrdkr-n|S|dd�}|r#|dd�dkr-|�dd��d	d�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
    rrsr�rNrHz\\�\z\")r2)r��is_filenamer;r;r<r��s"�r�cCsi}|D]}|j||j<q|S)z�Returns a key/value dictionary from a CookieJar.

    :param cj: CookieJar object to extract cookies from.
    :rtype: dict
    )r�rq)�cj�cookie_dict�cookier;r;r<�dict_from_cookiejar�sr�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�r;r;r<�add_dict_to_cookiejar�s
r�cCsTt�dt�tjdtjd�}tjdtjd�}t�d�}|�|�|�|�|�|�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=["\']*(.+?)["\'>])rOrP�DeprecationWarningr3�compiler5�findall)�content�
charset_re�	pragma_re�xml_rer;r;r<�get_encodings_from_content�s�
��r�c
Cs�|�d�}|d��|dd�}}i}d}|D]0}|��}|rH|d}}|�d�}	|	dkrB|d|	��|�}||	dd��|�}|||��<q||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�rs)r1�strip�find�lower)
�header�tokens�content_type�params�params_dict�items_to_strip�param�keyr��index_of_equalsr;r;r<�_parse_content_type_header�s


�r�cCsP|�d�}|s	dSt|�\}}d|vr|d�d�Sd|vr dSd|vr&dSdS)	z}Returns encodings from given HTTP Header Dict.

    :param headers: dictionary to extract encoding from.
    :rtype: str
    zcontent-typeN�charsetz'"�textz
ISO-8859-1zapplication/json�utf-8)r_r�r�)�headersr�r�r;r;r<�get_encoding_from_headers�s
�r�ccsp�|jdur|D]}|VqdSt�|j�dd�}|D]}|�|�}|r'|Vq|jddd�}|r6|VdSdS)zStream decodes a iterator.Nr2��errors�T)�final)�encoding�codecs�getincrementaldecoder�decode)�iterator�rr��decoder�chunk�rvr;r;r<�stream_decode_response_unicode�s�

�
�r�ccsX�d}|dus|dkrt|�}|t|�kr*||||�V||7}|t|�ksdSdS)z Iterate over slices of a string.rN)rC)�string�slice_length�posr;r;r<�iter_slicess��r�cCsvt�dt�g}t|j�}|r%zt|j|�WSty$|�|�Ynwz	t|j|dd�WSt	y:|jYSw)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.)r2r�)
rOrPr�r�r�rr��UnicodeErrorr��	TypeError)r��tried_encodingsr�r;r;r<�get_unicode_from_responses"�
�
�r�zBABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~c	Cs�|�d�}tdt|��D]M}||dd�}t|�dkrQ|��rQz	tt|d��}Wn
ty6td|��w|tvrH|||dd�||<qd||||<qd||||<qd�	|�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
    �%rrrH�z%Invalid percent-escape sequence: '%s'N�)
r1�rangerC�isalnum�chrr.r�r�UNRESERVED_SETr{)�uri�parts�i�h�cr;r;r<�unquote_unreserved>s
�
r�cCs:d}d}z	tt|�|d�WStyt||d�YSw)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!#$&'()*+,/:;=?@[]~)�safe)r	r�r)r��safe_with_percent�safe_without_percentr;r;r<�requote_uriVs�r�cCslt�dt�|��d}|�d�\}}t�dt�tt|����d}t�dt�|��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=Lrrz)�struct�unpack�socket�	inet_atonr1�dotted_netmaskr.)�ip�net�ipaddr�netaddr�bits�netmask�networkr;r;r<�address_in_networkls
r�cCs&ddd|>dA}t�t�d|��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�r;r;r<r�{sr�cCs(zt�|�WdStjyYdSw)z
    :rtype: bool
    FT)r�r��error)�	string_ipr;r;r<�is_ipv4_address�s��r�cCs�|�d�dkr@zt|�d�d�}Wn
tyYdSw|dks%|dkr'dSz
t�|�d�d�WdStjy?YdSwdS)zV
    Very simple check of the cidr format in no_proxy variable.

    :rtype: bool
    rzrFr�rT)�countr.r1r�r�r�r�)�string_networkr�r;r;r<�
is_valid_cidr�s���r�c	csz�|du}|rtj�|�}|tj|<zdVW|r*|dur#tj|=dS|tj|<dSdS|r<|dur7tj|=w|tj|<w)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)rKr^r_)�env_namer��
value_changed�	old_valuer;r;r<�set_environ�s�
�r�c	
Cs8dd�}|}|dur|d�}t|�}|jdurdS|rkdd�|�dd	��d
�D�}t|j�rJ|D]}t|�r@t|j|�r?dSq0|j|krHdSq0n!|j}|jrX|d�|j�7}|D]}|j�	|�sg|�	|�rjdSqZt
d|��zt|j�}Wntt
jfy�d}YnwWd�n1s�wY|r�dSdS)
zL
    Returns whether we should bypass proxies or not.

    :rtype: bool
    cSstj�|�p
tj�|���S�N)rKr^r_�upper)�kr;r;r<�<lambda>�sz'should_bypass_proxies.<locals>.<lambda>N�no_proxyTcss�|]}|r|VqdSr�r;)rYr6r;r;r<r[�s��
�z(should_bypass_proxies.<locals>.<genexpr>� r��,z:{}F)r
rer2r1r�r�r��portrX�endswithr�rr�r��gaierror)	rhr�	get_proxy�no_proxy_arg�parsed�proxy_ip�host_with_portr6�bypassr;r;r<�should_bypass_proxies�sN
�
�
��	����rcCst||d�riSt�S)zA
    Return a dict of environment proxies.

    :rtype: dict
    )r)rr)rhrr;r;r<�get_environ_proxies�srcCsv|pi}t|�}|jdur|�|j|�d��S|jd|j|jd|jdg}d}|D]
}||vr8||}|Sq+|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
rer_�scheme)rh�proxies�urlparts�
proxy_keys�proxy�	proxy_keyr;r;r<�select_proxys"
��r�python-requestscCsd|tfS)zO
    Return a string representing the default user agent.

    :rtype: str
    z%s/%sr)rqr;r;r<�default_user_agent"srcCstt�d�d�ddd��S)z9
    :rtype: requests.structures.CaseInsensitiveDict
    z, )�gzip�deflatez*/*z
keep-alive)z
User-AgentzAccept-Encoding�Accept�
Connection)rrr{r;r;r;r<�default_headers+s�rc	
Cs�g}d}|�|�}|s
|St�d|�D]M}z
|�dd�\}}Wnty-|d}}Ynwd|�d�i}|�d�D] }z	|�d�\}}Wn
tyOYnw|�|�||�|�<q:|�|�q|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�rhz<> '"r�)r�r3r1r�r�)	r��links�
replace_chars�valrhr��linkr�r�r;r;r<�parse_header_links7s*
��r$��asciirH�cCs�|dd�}|tjtjfvrdS|dd�tjkrdS|dd�tjtjfvr)dS|�t�}|dkr4d	S|dkrN|ddd�tkrCd
S|ddd�tkrNdS|dkrf|dd�t	kr\d
S|dd�t	krfdSdS)z
    :rtype: str
    N�zutf-32r'z	utf-8-sigrHzutf-16rr�z	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�	nullcountr;r;r<�guess_json_utfbs*
r4cCs8t||�\}}}}}}|s||}}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)rh�
new_schemer�netlocrar��query�fragmentr;r;r<�prepend_scheme_if_needed�s
r9c	Cs@t|�}z
t|j�t|j�f}W|Sttfyd}Y|Sw)z{Given a url with authentication components, extract them into a tuple of
    username,password.

    :rtype: (str,str)
    )r�r�)r
r
�username�passwordrgr�)rhr�authr;r;r<�get_auth_from_url�s��r=s^\S[^\r\n]*$|^$z^\S[^\r\n]*$|^$c	Cs^|\}}t|t�rt}nt}z|�|�std|��WdSty.td||t|�f��w)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)rvr�_CLEAN_HEADER_REGEX_BYTE�_CLEAN_HEADER_REGEX_STRr4rr��type)r�rqr��patr;r;r<�check_header_validity�s

���rBcCsFt|�\}}}}}}|s||}}|�dd�d}t|||||df�S)zW
    Given a url remove the fragment and the authentication part.

    :rtype: str
    �@rrsr�)r
�rsplitr)rhrr6rar�r7r8r;r;r<�
urldefragauth�s

rEc	CsVt|jdd�}|dur't|jt�r'z||j�WdSttfy&td��wtd��)zfMove file pointer back to its recorded starting position
    so it can be read again on redirect.
    rGNz;An error occurred when rewinding request body for redirect.z+Unable to rewind request body for redirect.)ru�bodyrv�_body_positionrrQr0r)�prepared_request�	body_seekr;r;r<�rewind_body�s�rJ)Fr�)r)b�__doc__r��
contextlibrIrKr3r�r��sysr�rOr|�collectionsrrr�r�_internal_utilsr�compatrr�r	r
rrr
rrrrrrrrr�cookiesr�
structuresr�
exceptionsrrrrr`�where�DEFAULT_CA_BUNDLE_PATH�
DEFAULT_PORTS�platformr=rArVrpryr�r�r�r�r�r�r�r�r�r�r�r�r�r��	frozensetr�r�r�r�r�r�r��contextmanagerr�rrrrrr$�encoder.r/r0r4r9r=r�r>r?rBrErJr;r;r;r<�<module>s�@

'	
=3  
#
%�

=
	
& 


Hacker Blog, Shell İndir, Sql İnjection, XSS Attacks, LFI Attacks, Social Hacking, Exploit Bot, Proxy Tools, Web Shell, PHP Shell, Alfa Shell İndir, Hacking Training Set, DDoS Script, Denial Of Service, Botnet, RFI Attacks, Encryption
Telegram @BIBIL_0DAY