File "response.cpython-37.pyc"

Full Path: /home/attunedd/public_html/byp/izo/con7ext_sym404/rintoar.txt/opt/alt/python37/lib/python3.7/site-packages/urllib3/__pycache__/response.cpython-37.pyc
File size: 20.03 KB
MIME-type: text/x-bytecode.python
Charset: 8 bit

B

`+n@sXddlmZddlZddlZddlZddlmZddlmZ	ddlm
ZyddlZWne
k
rldZYnXddlmZddlmZmZdd	lmZmZmZmZmZmZmZmZmZmZdd
lmZddl m!Z!m"Z"e#e$Z%Gdd
d
e&Z'Gddde&Z(Gddde&Z)edk	r*Gddde&Z*Gddde&Z+ddZ,Gdddej-Z.dS))absolute_importN)contextmanager)error)timeout)HTTPHeaderDict)BaseSSLError
HTTPException)
BodyNotHttplibCompatibleDecodeError	HTTPErrorIncompleteReadInvalidChunkLength
InvalidHeader
ProtocolErrorReadTimeoutErrorResponseNotChunkedSSLError)six)is_fp_closedis_response_to_headc@s$eZdZddZddZddZdS)DeflateDecodercCsd|_d|_t|_dS)NT)
_first_try_datazlib
decompressobj_obj)selfrA/opt/alt/python37/lib/python3.7/site-packages/urllib3/response.py__init__$szDeflateDecoder.__init__cCst|j|S)N)getattrr)rnamerrr __getattr__)szDeflateDecoder.__getattr__cCs|s|S|js|j|S|j|7_y |j|}|rFd|_d|_|Stjk
rd|_ttj|_z||jSd|_XYnXdS)NF)rr
decompressrrrr	MAX_WBITS)rdataZdecompressedrrr r%,s"zDeflateDecoder.decompressN)__name__
__module____qualname__r!r$r%rrrr r#src@seZdZdZdZdZdS)GzipDecoderStaterrN)r(r)r*FIRST_MEMBER
OTHER_MEMBERSSWALLOW_DATArrrr r+Csr+c@s$eZdZddZddZddZdS)GzipDecodercCstdtj|_tj|_dS)N)rrr&rr+r-_state)rrrr r!KszGzipDecoder.__init__cCst|j|S)N)r"r)rr#rrr r$OszGzipDecoder.__getattr__cCst}|jtjks|st|Sxy||j|7}Wn8tjk
rl|j}tj|_|tj	krft|SYnX|jj
}|st|Stj	|_tdtj|_q WdS)Nr1)
	bytearrayr2r+r/bytesrr%rrr.unused_datarr&)rr'retZprevious_staterrr r%Rs"
zGzipDecoder.decompressN)r(r)r*r!r$r%rrrr r0Jsr0c@seZdZddZddZdS)
BrotliDecodercCs0t|_t|jdr"|jj|_n
|jj|_dS)Nr%)brotliZDecompressorrhasattrr%process)rrrr r!ns
zBrotliDecoder.__init__cCst|jdr|jSdS)Nflushr)r9rr;)rrrr r;us
zBrotliDecoder.flushN)r(r)r*r!r;rrrr r7jsr7c@s(eZdZdZddZddZddZdS)	MultiDecodera
    From RFC7231:
        If one or more encodings have been applied to a representation, the
        sender that applied the encodings MUST generate a Content-Encoding
        header field that lists the content codings in the order in which
        they were applied.
    cCsdd|dD|_dS)NcSsg|]}t|qSr)_get_decoderstrip).0mrrr 
<listcomp>sz)MultiDecoder.__init__.<locals>.<listcomp>,)split	_decoders)rZmodesrrr r!szMultiDecoder.__init__cCs|jdS)Nr)rDr;)rrrr r;szMultiDecoder.flushcCs"xt|jD]}||}qW|S)N)reversedrDr%)rr'drrr r%szMultiDecoder.decompressN)r(r)r*__doc__r!r;r%rrrr r<{sr<cCs:d|krt|S|dkrtStdk	r4|dkr4tStS)NrBgzipbr)r<r0r8r7r)moderrr r=sr=c@sleZdZdZddgZedk	r&edg7Zdddd	d
gZdNddZddZddZ	ddZ
eddZeddZ
ddZddZdd Zd!d"ZeejfZedk	reejf7Zd#d$Zd%d&Zed'd(ZdOd)d*ZdPd,d-Zed.d/Zd0d1ZdQd2d3Zd4d5Z d6d7Z!ed8d9Z"d:d;Z#d<d=Z$d>d?Z%d@dAZ&dBdCZ'dDdEZ(dFdGZ)dRdHdIZ*dJdKZ+dLdMZ,dS)SHTTPResponsea
    HTTP Response container.

    Backwards-compatible with :class:`http.client.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 :class:`http.client.HTTPResponse`:

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

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

    :param original_response:
        When this HTTPResponse wrapper is generated from an :class:`http.client.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.
    rHdeflateNrIi-i.i/i3i4rTFcCst|tr||_n
t||_||_||_||_||_||_|
|_||_	||_
d|_d|_d|_
|	|_d|_||_||_|rt|tjtfr||_|
|_||_t|dr||_
d|_d|_|jdd}dd|dD}d	|krd
|_|||_|r|js|j|d|_dS)NrreadFztransfer-encodingrMcss|]}|VqdS)N)r>)r?encrrr 	<genexpr>sz(HTTPResponse.__init__.<locals>.<genexpr>rBchunkedT)decode_content) 
isinstancerheadersstatusversionreasonstrictrRretriesenforce_content_length
auto_close_decoder_body_fp_original_response_fp_bytes_readmsg_request_urlrstring_typesr4_pool_connectionr9rQ
chunk_leftgetlowerrC_init_lengthlength_remainingrN)rbodyrTrUrVrWrXZpreload_contentrRoriginal_responsepool
connectionrarYrZrequest_methodZrequest_urlr[Ztr_enc	encodingsrrr r!sB


zHTTPResponse.__init__cCs|j|jkr|jdSdS)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)rUREDIRECT_STATUSESrTrg)rrrr get_redirect_locationsz"HTTPResponse.get_redirect_locationcCs(|jr|jsdS|j|jd|_dS)N)rdreZ	_put_conn)rrrr release_connszHTTPResponse.release_conncCs.y|Wnttttfk
r(YnXdS)z
        Read and discard any remaining HTTP response data in the response connection.

        Unread data in the HTTPResponse connection blocks the connection from being released back to the pool.
        N)rNrSocketErrorrr	)rrrr 
drain_connszHTTPResponse.drain_conncCs"|jr|jS|jr|jddSdS)NT)
cache_content)r]r^rN)rrrr r'%szHTTPResponse.datacCs|jS)N)re)rrrr rn.szHTTPResponse.connectioncCs
t|jS)N)rr^)rrrr isclosed2szHTTPResponse.isclosedcCs|jS)z
        Obtain the number of bytes pulled over the wire so far. May differ from
        the amount of content returned by :meth:``urllib3.response.HTTPResponse.read``
        if bytes are encoded on the wire (e.g, compressed).
        )r`)rrrr tell5szHTTPResponse.tellcCs|jd}|dk	r|jr(tddSy<tdd|dD}t|dkrZtd||	}Wnt
k
r|d}YnX|d	krd}yt|j}Wnt
k
rd	}YnX|d
ksd|krdksn|d
krd	}|S)zM
        Set initial length value for Response content if available.
        zcontent-lengthNzReceived 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)r?valrrr rAWsz-HTTPResponse._init_length.<locals>.<listcomp>rBrz8Content-Length contained multiple unmatching values (%s)r)i0dZHEAD)
rTrgrQlogwarningsetrClenrpop
ValueErrorrzrU)rrolengthZlengthsrUrrr ri=s0

&zHTTPResponse._init_lengthcshjdd}jdkrd|jkr2t|_n2d|krdfdd|dD}t|rdt|_dS)z=
        Set-up the _decoder attribute if necessary.
        zcontent-encodingrMNrBcs"g|]}|jkr|qSr)r>CONTENT_DECODERS)r?e)rrr rA}sz.HTTPResponse._init_decoder.<locals>.<listcomp>)rTrgrhr\rr=rCr)rcontent_encodingrpr)rr 
_init_decoderqs


zHTTPResponse._init_decoderc
Csx|s|Sy|jr|j|}WnD|jk
rb}z$|jdd}td||Wdd}~XYnX|rt||7}|S)zN
        Decode the data passed in and potentially flush the decoder.
        zcontent-encodingrMzEReceived response with content-encoding: %s, but failed to decode it.N)r\r%DECODER_ERROR_CLASSESrTrgrhr_flush_decoder)rr'rR
flush_decoderrrrrr _decodeszHTTPResponse._decodecCs$|jr |jd}||jSdS)zk
        Flushes the decoder. Should only be called if the decoder is actually
        being used.
        r)r\r%r;)rbufrrr rszHTTPResponse._flush_decoderc
csd}zy
dVWntk
r2t|jddYnvtk
rt}z&dt|krVt|t|jddWdd}~XYn4ttfk
r}ztd||Wdd}~XYnXd}Wd|s|j	r|j	
|jr|j
|j	r|j	r|
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)
SocketTimeoutrrdrstrrr	rurr_closererxrt)rZ
clean_exitrrrr _error_catchers(	
 

zHTTPResponse._error_catcherc	Cs||dkr|j}|jdkr$dSd}t|jdd}|v|dkr`|sV|jnd}d}nPd}|st|j|nd}|dkr|s|jd}|jr|jdkrt	|j
|jWdQRX|r|j
t|7_
|jdk	r|jt|8_||||}|r||_
|S)aT
        Similar to :meth:`http.client.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.)
        NFclosedrTr)rN)rrRr^r"rrNrrZrjr
r`rrr])ramtrRrwrZ	fp_closedr'rrr rNs6

	


zHTTPResponse.readccsZ|jr.|r.xF|j||dD]
}|VqWn(x&t|jsT|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.
        )rR)rrRN)rQsupports_chunked_readsread_chunkedrr^rN)rrrRliner'rrr stream+szHTTPResponse.streamc
Ksb|j}t|ts.tjr"t|}nt|}t|dd}|f|||j|j	|j
||d|}|S)a
        Given an :class:`http.client.HTTPResponse` instance ``r``, return a
        corresponding :class:`urllib3.response.HTTPResponse` object.

        Remaining parameters are passed to the HTTPResponse constructor, along
        with ``original_response=r``.
        rXr)rkrTrUrVrWrXrl)rarSrrPY2from_httplibitemsr"rUrVrW)ZResponseClsrZresponse_kwrTrXZresprrr rEs 	
zHTTPResponse.from_httplibcCs|jS)N)rT)rrrr 
getheadersfszHTTPResponse.getheaderscCs|j||S)N)rTrg)rr#defaultrrr 	getheaderiszHTTPResponse.getheadercCs|jS)N)rT)rrrr infomszHTTPResponse.infocCs6|js|j|jr |j|js2tj|dS)N)rr^rrer[ioIOBase)rrrr rqs

zHTTPResponse.closecCsT|jstjj|S|jdkr"dSt|jdr8|jSt|jdrL|jjSdSdS)NTrxr)r[rrr__get__r^r9rx)rrrr r{s

zHTTPResponse.closedcCs6|jdkrtdnt|jdr*|jStddS)Nz-HTTPResponse has no file to get a fileno fromfilenozOThe file-like object this HTTPResponse is wrapped around has no file descriptor)r^IOErrorr9r)rrrr rs


zHTTPResponse.filenocCs2|jdk	r.t|jdr.t|jdds.|jSdS)Nr;rF)r^r9r"r;)rrrr r;s
zHTTPResponse.flushcCsdS)NTr)rrrr readableszHTTPResponse.readablecCs:|t|}t|dkrdS||dt|<t|SdS)Nr)rNr)rbtemprrr readintos
zHTTPResponse.readintocCst|jdS)a
        Checks if the underlying file-like object looks like a
        :class:`http.client.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)r9r^)rrrr rsz#HTTPResponse.supports_chunked_readscCsf|jdk	rdS|jj}|ddd}yt|d|_Wn&tk
r`|t||YnXdS)N;rrr1)	rfr^rreadlinerCrzrrr)rrrrr _update_chunk_lengths
z!HTTPResponse._update_chunk_lengthcCsd}|dkr2|j|j}|}|jdd|_nv||jkrZ|j|}|j||_|}nN||jkr|j|}|jdd|_|}n |j|j}|jdd|_|S)Nr,)r^Z
_safe_readrf)rrZreturned_chunkchunkvaluerrr 
_handle_chunks&

zHTTPResponse._handle_chunkc	cs||jstd|s&td||jrNt|jrN|jdS|j	j
dkr^dSx<||jdkrtP|
|}|j||dd}|r`|Vq`W|r|}|r|Vx |j	j
}|sP|dkrPqW|jr|jWdQRXdS)a
        Similar to :meth:`HTTPResponse.read`, but with an additional
        parameter: ``decode_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.
        zHResponse is not chunked. Header 'transfer-encoding: chunked' is missing.zkBody should be http.client.HTTPResponse like. It should have have an fp attribute which returns raw chunks.NrF)rRrs
)rrQrrr
rr_rrr^rrrfrrrr)rrrRrdecodedrrrr rsD




zHTTPResponse.read_chunkedcCs.|jdk	r$t|jjr$|jjdjS|jSdS)z
        Returns the URL that was the source of this response.
        If the request that generated this response redirected, this method
        will return the final redirect location.
        N)rYrhistoryZredirect_locationrb)rrrr geturlszHTTPResponse.geturlccsg}x|jddD]r}d|krz|d}d||ddVx|ddD]}|dVqNW|drt|dg}qg}q||qW|rd|VdS)NT)rR
rrrr)rrCjoinappend)rbufferrxrrr __iter__&s
zHTTPResponse.__iter__)rMNrrNrTTNNNNNFNNT)NNF)rN)N)NN)-r(r)r*rGrr8rrr!rsrtrvpropertyr'rnrxryrirrrrrrrrrrNrclassmethodrrrrrrrr;rrrrrrrrrrrr rKsn

1
	4
8
J
!


		
FrK)/
__future__rrloggingr
contextlibrsocketrrurrr8ImportError_collectionsrrnrr	
exceptionsr
rrr
rrrrrrpackagesrZ
util.responserr	getLoggerr(robjectrr+r0r7r<r=rrKrrrr <module>s0
0