HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ns3133907 6.8.0-86-generic #87-Ubuntu SMP PREEMPT_DYNAMIC Mon Sep 22 18:03:36 UTC 2025 x86_64
User: cssnetorguk (1024)
PHP: 8.2.28
Disabled: NONE
Upload Files
File: //snap/core18/current/usr/lib/python3/dist-packages/urllib3/__pycache__/response.cpython-36.pyc
3

&�[hcY�@sddlmZddlmZddlZddlZddlZddlmZ	ddlm
Zddlm
Z
ddlmZmZmZmZmZmZmZdd	lmZmZmZdd
lmZddlmZm Z ddl!m"Z"m#Z#ej$e%�Z&Gd
d�de'�Z(Gdd�de'�Z)dd�Z*Gdd�dej+�Z,dS)�)�absolute_import)�contextmanagerN)�timeout)�error�)�HTTPHeaderDict)�BodyNotHttplibCompatible�
ProtocolError�DecodeError�ReadTimeoutError�ResponseNotChunked�IncompleteRead�
InvalidHeader)�string_types�binary_type�PY3)�http_client)�
HTTPException�BaseSSLError)�is_fp_closed�is_response_to_headc@s$eZdZdd�Zdd�Zdd�ZdS)�DeflateDecodercCsd|_t�|_tj�|_dS)NT)�
_first_tryr�_data�zlib�
decompressobj�_obj)�self�r�2/usr/lib/python3/dist-packages/urllib3/response.py�__init__szDeflateDecoder.__init__cCst|j|�S)N)�getattrr)r�namerrr�__getattr__szDeflateDecoder.__getattr__cCs�|s|S|js|jj|�S|j|7_y |jj|�}|rFd|_d|_|Stjk
r�d|_tjtj�|_z|j|j�Sd|_XYnXdS)NF)rr�
decompressrrrr�	MAX_WBITS)r�dataZdecompressedrrrr$ s"zDeflateDecoder.decompressN)�__name__�
__module__�__qualname__r r#r$rrrrrsrc@s$eZdZdd�Zdd�Zdd�ZdS)�GzipDecodercCstjdtj�|_dS)N�)rrr%r)rrrrr 9szGzipDecoder.__init__cCst|j|�S)N)r!r)rr"rrrr#<szGzipDecoder.__getattr__cCs|s|S|jj|�S)N)rr$)rr&rrrr$?szGzipDecoder.decompressN)r'r(r)r r#r$rrrrr*7sr*cCs|dkrt�St�S)N�gzip)r*r)�moderrr�_get_decoderEsr.c@seZdZdZddgZdddddgZdFdd�Zdd�Zdd�Ze	dd��Z
e	dd��Zdd�Zdd�Z
dd�Zdd�Zd d!�Zed"d#��ZdGd$d%�ZdId(d)�Zed*d+��Zd,d-�ZdJd.d/�Zd0d1�Zd2d3�Ze	d4d5��Zd6d7�Zd8d9�Zd:d;�Zd<d=�Zd>d?�Z d@dA�Z!dBdC�Z"dKdDdE�Z#d
S)L�HTTPResponsea	
    HTTP Response container.

    Backwards-compatible to httplib's HTTPResponse but the response ``body`` is
    loaded and decoded on-demand when the ``data`` property is accessed.  This
    class is also compatible with the Python standard library's :mod:`io`
    module, and can hence be treated as a readable object in the context of that
    framework.

    Extra parameters for behaviour not present in httplib.HTTPResponse:

    :param preload_content:
        If True, the response's body will be preloaded during construction.

    :param decode_content:
        If True, attempts to decode specific content-encoding's based on headers
        (like 'gzip' and 'deflate') will be skipped and raw data will be used
        instead.

    :param original_response:
        When this HTTPResponse wrapper is generated from an httplib.HTTPResponse
        object, it's convenient to include the original for debug purposes. It's
        otherwise unused.

    :param retries:
        The retries contains the last :class:`~urllib3.util.retry.Retry` that
        was used during the request.

    :param enforce_content_length:
        Enforce content length checking. Body returned by server must match
        value of Content-Length header, if present. Otherwise, raise error.
    r,Zdeflatei-i.i/i3i4�NrTFcCst|t�r||_n
t|�|_||_||_||_||_||_||_|
|_	d|_
d|_d|_|	|_
d|_|r|t|ttf�r|||_|
|_||_t|d�r�||_d|_d|_|jjdd�j�}dd�|jd�D�}d	|kr�d
|_|j|�|_|r�|jr�|j|d�|_dS)Nr�readFztransfer-encodingr0css|]}|j�VqdS)N)�strip)�.0�encrrr�	<genexpr>�sz(HTTPResponse.__init__.<locals>.<genexpr>�,�chunkedT)�decode_content)�
isinstancer�headers�status�version�reason�strictr8�retries�enforce_content_length�_decoder�_body�_fp�_original_response�_fp_bytes_read�
basestringr�_pool�_connection�hasattrr7�
chunk_left�get�lower�split�_init_length�length_remainingr1)r�bodyr:r;r<r=r>Zpreload_contentr8�original_responseZpool�
connectionr?r@�request_methodZtr_encZ	encodingsrrrr qs<


zHTTPResponse.__init__cCs|j|jkr|jjd�SdS)a
        Should we redirect and where to?

        :returns: Truthy redirect location string if we got a redirect status
            code and valid location. ``None`` if redirect status and no
            location. ``False`` if not a redirect status code.
        �locationF)r;�REDIRECT_STATUSESr:rK)rrrr�get_redirect_location�sz"HTTPResponse.get_redirect_locationcCs,|js|jrdS|jj|j�d|_dS)N)rGrHZ	_put_conn)rrrr�release_conn�szHTTPResponse.release_conncCs"|jr|jS|jr|jdd�SdS)NT)�
cache_content)rBrCr1)rrrrr&�szHTTPResponse.datacCs|jS)N)rH)rrrrrR�szHTTPResponse.connectioncCs|jS)z�
        Obtain the number of bytes pulled over the wire so far. May differ from
        the amount of content returned by :meth:``HTTPResponse.read`` if bytes
        are encoded on the wire (e.g, compressed).
        )rE)rrrr�tell�szHTTPResponse.tellcCs�|jjd�}|dk	r(|jr(tjd�dS|dk	r�y<tdd�|jd�D��}t|�dkrbtd|��|j	�}Wnt
k
r�d}YnX|d	kr�d}yt|j�}Wnt
k
r�d	}YnX|dks�d|ko�d
kns�|dkr�d	}|S)zM
        Set initial length value for Response content if available.
        zcontent-lengthNz�Received response with both Content-Length and Transfer-Encoding set. This is expressly forbidden by RFC 7230 sec 3.3.2. Ignoring Content-Length and attempting to process response as Transfer-Encoding: chunked.cSsg|]}t|��qSr)�int)r3�valrrr�
<listcomp>�sz-HTTPResponse._init_length.<locals>.<listcomp>r6rz8Content-Length contained multiple unmatching values (%s)r���0�d��ZHEAD)r]r^)
r:rKr7�logZwarning�setrM�lenr�pop�
ValueErrorrZr;)rrSZlengthZlengthsr;rrrrN�s,


(zHTTPResponse._init_lengthcCs4|jjdd�j�}|jdkr0||jkr0t|�|_dS)z=
        Set-up the _decoder attribute if necessary.
        zcontent-encodingr0N)r:rKrLrA�CONTENT_DECODERSr.)r�content_encodingrrr�
_init_decoder�szHTTPResponse._init_decodercCs|y|r|jr|jj|�}WnHttjfk
rb}z&|jjdd�j�}td||��WYdd}~XnX|rx|rx||j	�7}|S)zN
        Decode the data passed in and potentially flush the decoder.
        zcontent-encodingr0zEReceived response with content-encoding: %s, but failed to decode it.N)
rAr$�IOErrorrrr:rKrLr
�_flush_decoder)rr&r8�
flush_decoder�ergrrr�_decodes
zHTTPResponse._decodecCs$|jr |jjd�}||jj�SdS)zk
        Flushes the decoder. Should only be called if the decoder is actually
        being used.
        �)rAr$�flush)rZbufrrrrjszHTTPResponse._flush_decoderccs�d}z�y
dVWn�tk
r2t|jdd��Ynptk
rn}z"dt|�krP�t|jdd��WYdd}~Xn4ttfk
r�}ztd||��WYdd}~XnXd}Wd|s�|jr�|jj	�|j
r�|j
j	�|jr�|jj�r�|j�XdS)z�
        Catch low-level python exceptions, instead re-raising urllib3
        variants, so that low-level exceptions are not leaked in the
        high-level api.

        On exit, release the connection back to the pool.
        FNzRead timed out.zread operation timed outzConnection broken: %rT)
�
SocketTimeoutrrGr�strr�SocketErrorr	rD�closerH�isclosedrW)rZ
clean_exitrlrrr�_error_catcher!s(	
 

zHTTPResponse._error_catchercCs�|j�|dkr|j}|jdkr$dSd}d}|j��h|dkrN|jj�}d}nJd}|jj|�}|dkr�|r�|jj�d}|jr�|jdkr�t|j	|j��WdQRX|r�|j	t
|�7_	|jdk	r�|jt
|�8_|j|||�}|r�||_|S)aP
        Similar to :meth:`httplib.HTTPResponse.read`, but with two additional
        parameters: ``decode_content`` and ``cache_content``.

        :param amt:
            How much of the content to read. If specified, caching is skipped
            because it doesn't make sense to cache partial content as the full
            response.

        :param decode_content:
            If True, will attempt to decode the body based on the
            'content-encoding' header.

        :param cache_content:
            If True, will save the returned data such that the same result is
            returned despite of the state of the underlying file object. This
            is useful if you want the ``.data`` property to continue working
            after having ``.read()`` the file object. (Overridden if ``amt`` is
            set.)
        NFTr)rN)
rhr8rCrur1rsr@rOr
rErcrmrB)r�amtr8rXrkr&rrrr1Zs4




zHTTPResponse.read�r+ccsZ|jr.|j�r.xF|j||d�D]
}|VqWn(x&t|j�sT|j||d�}|r0|Vq0WdS)a_
        A generator wrapper for the read() method. A call will block until
        ``amt`` bytes have been read from the connection or until the
        connection is closed.

        :param amt:
            How much of the content to read. The generator will return up to
            much data per iteration, but may return less. This is particularly
            likely when using compressed data. However, the empty string will
            never be returned.

        :param decode_content:
            If True, will attempt to decode the body based on the
            'content-encoding' header.
        )r8)rvr8N)r7�supports_chunked_reads�read_chunkedrrCr1)rrvr8�liner&rrr�stream�szHTTPResponse.streamc
Ks`|j}t|t�s,tr"t|j��}n
tj|�}t|dd�}|f|||j|j|j	||d�|��}|S)a
        Given an :class:`httplib.HTTPResponse` instance ``r``, return a
        corresponding :class:`urllib3.response.HTTPResponse` object.

        Remaining parameters are passed to the HTTPResponse constructor, along
        with ``original_response=r``.
        r>r)rPr:r;r<r=r>rQ)
�msgr9rr�items�from_httplibr!r;r<r=)ZResponseCls�rZresponse_kwr:r>Zresprrrr~�s	

zHTTPResponse.from_httplibcCs|jS)N)r:)rrrr�
getheaders�szHTTPResponse.getheaderscCs|jj||�S)N)r:rK)rr"�defaultrrr�	getheader�szHTTPResponse.getheadercCs|jS)N)r:)rrrr�info�szHTTPResponse.infocCs$|js|jj�|jr |jj�dS)N)�closedrCrsrH)rrrrrs�s
zHTTPResponse.closecCs@|jdkrdSt|jd�r$|jj�St|jd�r8|jjSdSdS)NTrtr�)rCrIrtr�)rrrrr��s

zHTTPResponse.closedcCs6|jdkrtd��nt|jd�r*|jj�Std��dS)Nz-HTTPResponse has no file to get a fileno from�filenozOThe file-like object this HTTPResponse is wrapped around has no file descriptor)rCrirIr�)rrrrr��s



zHTTPResponse.filenocCs$|jdk	r t|jd�r |jj�SdS)Nro)rCrIro)rrrrro�szHTTPResponse.flushcCsdS)NTr)rrrr�readableszHTTPResponse.readablecCs:|jt|��}t|�dkrdS||dt|��<t|�SdS)Nr)r1rc)r�bZtemprrr�readintos
zHTTPResponse.readintocCst|jd�S)z�
        Checks if the underlying file-like object looks like a
        httplib.HTTPResponse object. We do this by testing for the fp
        attribute. If it is present we assume it returns raw chunks as
        processed by read_chunked().
        �fp)rIrC)rrrrrxsz#HTTPResponse.supports_chunked_readscCsf|jdk	rdS|jjj�}|jdd�d}yt|d�|_Wn&tk
r`|j�tj	|��YnXdS)N�;rrr+)
rJrCr��readlinerMrZrers�httplibr
)rrzrrr�_update_chunk_lengths
z!HTTPResponse._update_chunk_lengthcCs�d}|dkr2|jj|j�}|}|jjd�d|_nv||jkrZ|jj|�}|j||_|}nN||jkr�|jj|�}|jjd�d|_|}n |jj|j�}|jjd�d|_|S)Nrw)rCZ
_safe_readrJ)rrvZreturned_chunk�chunk�valuerrr�
_handle_chunk%s&

zHTTPResponse._handle_chunkccs�|j�|jstd��|j�s&td��|jrDt|j�rD|jj�dS|j���x<|j	�|j
dkrdP|j|�}|j||dd�}|rP|VqPW|r�|j
�}|r�|Vx |jjj�}|s�P|dkr�Pq�W|jr�|jj�WdQRXdS)z�
        Similar to :meth:`HTTPResponse.read`, but with an additional
        parameter: ``decode_content``.

        :param decode_content:
            If True, will attempt to decode the body based on the
            'content-encoding' header.
        zHResponse is not chunked. Header 'transfer-encoding: chunked' is missing.zgBody should be httplib.HTTPResponse like. It should have have an fp attribute which returns raw chunks.NrF)r8rks
)rhr7rrxrrDrrsrur�rJr�rmrjrCr�r�)rrvr8r�Zdecodedrzrrrry;s@	




zHTTPResponse.read_chunked)r0NrrNrTTNNNNFN)NNF�)r�N)N)NN)$r'r(r)�__doc__rfrUr rVrW�propertyr&rRrYrNrhrmrjrrur1r{�classmethodr~r�r�r�rsr�r�ror�r�rxr�r�ryrrrrr/LsB 
-
	0
9
E

			r/)-Z
__future__r�
contextlibrr�ioZloggingZsocketrrprrr�_collectionsr�
exceptionsrr	r
rrr
rZsixrrFrrZ	six.movesrr�rRrrZ
util.responserrZ	getLoggerr'ra�objectrr*r.�IOBaser/rrrr�<module>s"$
!