hyb
2025-11-10 e0a856b5072c5a09f3f6de6da85abf90e00ee704
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
Ë
ñúh±wãóš—ddlmZddlZddlZddlZddlZddlZddlmZddl    m
Z ddl    m Z dZddlmZddlmZdd    lmZmZdd
lmZmZmZmZmZmZmZmZmZm Z dd l!m"Z"dd l#m$Z$m%Z%ejLe'«Z(Gd „de)«Z*Gd„de)«Z+Gd„de)«Z,e Gd„de)«Z-Gd„de)«Z.d„Z/Gd„dej`«Z1y)é)Úabsolute_importN)Úcontextmanager)Úerror)Útimeouté)Úutil)ÚHTTPHeaderDict)Ú BaseSSLErrorÚ HTTPException)
ÚBodyNotHttplibCompatibleÚ DecodeErrorÚ    HTTPErrorÚIncompleteReadÚInvalidChunkLengthÚ InvalidHeaderÚ ProtocolErrorÚReadTimeoutErrorÚResponseNotChunkedÚSSLError)Úsix)Ú is_fp_closedÚis_response_to_headcó—eZdZd„Zd„Zd„Zy)ÚDeflateDecodercóR—d|_d|_tj«|_y)NTó)Ú
_first_tryÚ_dataÚzlibÚ decompressobjÚ_obj©Úselfs úOH:\Change_password\venv_build\Lib\site-packages\pip/_vendor/urllib3/response.pyÚ__init__zDeflateDecoder.__init__$s €ØˆŒØˆŒ
Ü×&Ñ&Ó(ˆ    rcó.—t|j|«S©N©Úgetattrr!©r#Únames  r$Ú __getattr__zDeflateDecoder.__getattr__)ó€Üt—y‘y $Ó'Ð'rcóΗ|s|S|js|jj|«S|xj|z c_    |jj|«}|rd|_d|_|S#tj
$rbd|_t    j tj «|_    |j|j«d|_cYS#d|_wxYwwxYw)NF)rr!Ú
decompressrrrr Ú    MAX_WBITS)r#ÚdataÚ decompresseds   r$r/zDeflateDecoder.decompress,sº€Ù؈KàŠØ—9‘9×'Ñ'¨Ó-Ð -à 
Š
dэ
ð     "ØŸ9™9×/Ñ/°Ó5ˆLÙØ"'”Ø!”
ØÐ øÜz‰zò    "Ø#ˆDŒOÜ×*Ñ*¬D¯N©N¨?Ó;ˆDŒIð "Ø—‘ t§z¡zÓ2à!—
ø˜T•
úð     "ús%Á,A/Á/AC$Â3Cà C$à   C àC$N©Ú__name__Ú
__module__Ú __qualname__r%r,r/©rr$rr#s„ò)ò
(ó"rrcó—eZdZdZdZdZy)ÚGzipDecoderStaterréN)r4r5r6Ú FIRST_MEMBERÚ OTHER_MEMBERSÚ SWALLOW_DATAr7rr$r9r9Cs„à€LØ€M؁Lrr9có—eZdZd„Zd„Zd„Zy)Ú GzipDecodercó„—tjdtjz«|_tj
|_y©Né)rr r0r!r9r;Ú_stater"s r$r%zGzipDecoder.__init__Ks*€Ü×&Ñ& r¬D¯N©NÑ':Ó;ˆŒ    Ü&×3Ñ3ˆ rcó.—t|j|«Sr'r(r*s  r$r,zGzipDecoder.__getattr__Or-rcó$—t«}|jtjk(s|s t    |«S        ||j
j |«z }|j
j}|s t    |«Stj|_tjdtjz«|_Œƒ#tj$rC|j}tj|_|tjk(r t    |«cYS‚wxYwrA) Ú    bytearrayrCr9r=Úbytesr!r/rrr<Ú unused_datar r0)r#r1ÚretÚprevious_states    r$r/zGzipDecoder.decompressRsۀÜ‹kˆØ ;‰;Ô*×7Ñ7Ò 7¹tܘ“:Ð Øð     ؐt—y‘y×+Ñ+¨DÓ1Ñ1ð—9‘9×(Ñ(ˆDÙܘS“zÐ!Ü*×8Ñ8ˆDŒKÜ×*Ñ*¨2´·±Ñ+>Ó?ˆDŒIðøô—:‘:ò Ø!%§¡ä.×;Ñ;” Ø!Ô%5×%CÑ%CÒCä  ›:Ò%Øð ús·B9Â9ADÄ DNr3r7rr$r?r?Js„ò4ò(ó@rr?có—eZdZd„Zd„Zy)Ú BrotliDecodercóЗtj«|_t|jd«r|jj|_y|jj
|_y)Nr/)ÚbrotliÚ Decompressorr!Úhasattrr/Úprocessr"s r$r%zBrotliDecoder.__init__nsB€Ü×+Ñ+Ó-ˆDŒIܐt—y‘y ,Ô/Ø"&§)¡)×"6Ñ"6•à"&§)¡)×"3Ñ"3•rcód—t|jd«r|jj«Sy)NÚflushr)rPr!rSr"s r$rSzBrotliDecoder.flushus$€Üt—y‘y 'Ô*Ø—y‘y—‘Ó(Ð(ØrN)r4r5r6r%rSr7rr$rLrLjs „ò    4ó    rrLcó"—eZdZdZd„Zd„Zd„Zy)Ú 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.
    có„—|jd«Dcgc]}t|j««‘Œc}|_ycc}w)Nú,)ÚsplitÚ _get_decoderÚstripÚ    _decoders)r#ÚmodesÚms   r$r%zMultiDecoder.__init__„s+€Ø;@¿;¹;ÀsÓ;KÖL°aœ, q§w¡w£yÕ1ÒLˆùÒLs” =có<—|jdj«S©Nr)r[rSr"s r$rSzMultiDecoder.flush‡s€Ø~‰~˜aÑ ×&Ñ&Ó(Ð(rcó\—t|j«D]}|j|«}Œ|Sr')Úreversedr[r/)r#r1Úds   r$r/zMultiDecoder.decompressŠs-€Ü˜$Ÿ.™.Ó)ò    &ˆAØ—<‘< Ó%‰Dð    &àˆ rN)r4r5r6Ú__doc__r%rSr/r7rr$rUrU{s„ñòMò)órrUcó|—d|vr t|«S|dk(r
t«St|dk(r
t«St    «S)NrWÚgzipÚbr)rUr?rNrLr)Úmodes r$rYrYs@€Ø
ˆd{ܘDÓ!Ð!à ˆv‚~Ü‹}Ðä Иd dšlÜ‹Ðä Ó ÐrcóŽ—eZdZdZddgZeedgz Zgd¢Z                                                                    d'd„Zd„Zd    „Z    d
„Z
e d „«Z e d „«Z d „Zd„Zd„Zd„Zeej(fZeeej(fz Zd„Zd„Zed„«Zd„Zd(d„Zd)d„Zed„«Zd„Zd*d„Z d„Z!d„Z"e d„«Z#d„Z$d„Z%d„Z&d „Z'd!„Z(d"„Z)d#„Z*d+d$„Z+d%„Z,d&„Z-y),Ú 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.
    reÚdeflateNrf)i-i.i/i3i4cóê—t|t«r||_nt|«|_||_||_||_||_||_| |_||_    ||_
d|_ d|_ d|_ |    |_d|_| |_||_|r't|t$j&t(f«r||_ |
|_| |_t/|d«r||_ d|_d|_|jj5dd«j7«}d„|j9d«D«}d|vrd    |_|j;|«|_|r%|js|j?|¬
«|_ yyy) NrÚreadFztransfer-encodingÚc3ó<K—|]}|j«–—Œy­wr')rZ)Ú.0Úencs  r$ú    <genexpr>z(HTTPResponse.__init__.<locals>.<genexpr>ûsèø€Ò> SS—Y‘Y—[Ñ>ùs‚rWÚchunkedT©Údecode_content) Ú
isinstancer    ÚheadersÚstatusÚversionÚreasonÚstrictrtÚretriesÚenforce_content_lengthÚ
auto_closeÚ_decoderÚ_bodyÚ_fpÚ_original_responseÚ_fp_bytes_readÚmsgÚ _request_urlrÚ string_typesrGÚ_poolÚ _connectionrPrrÚ
chunk_leftÚgetÚlowerrXÚ _init_lengthÚlength_remainingrl)r#ÚbodyrvrwrxryrzÚpreload_contentrtÚoriginal_responseÚpoolÚ
connectionrƒr{r|Úrequest_methodÚ request_urlr}Útr_encÚ    encodingss                    r$r%zHTTPResponse.__init__ÃsX€ô* gœ~Ô .Ø"ˆDLä)¨'Ó2ˆDŒL؈Œ ؈Œ ؈Œ ؈Œ Ø,ˆÔ؈Œ Ø&<ˆÔ#Ø$ˆŒàˆŒ ؈Œ
؈ŒØ"3ˆÔØˆÔØˆŒØ'ˆÔá ”J˜t¤c×&6Ñ&6¼Ð%>Ô?؈DŒJàˆŒ
Ø%ˆÔä 4˜Ô  ØˆDŒHðˆŒ ØˆŒØ—‘×!Ñ!Ð"5°rÓ:×@Ñ@ÓBˆá>¨F¯L©L¸Ó,=Ô>ˆ    Ø ˜    Ñ !؈DŒLð!%× 1Ñ 1°.Ó AˆÔñ  4§:¢:ØŸ™°.˜ÓAˆDJð$.ˆ?rcój—|j|jvr|jjd«Sy)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)rwÚREDIRECT_STATUSESrvr‰r"s r$Úget_redirect_locationz"HTTPResponse.get_redirect_locations.€ð ;‰;˜$×0Ñ0Ñ 0Ø—<‘<×#Ñ# JÓ/Ð /àrcóŽ—|jr |jsy|jj|j«d|_yr')r†r‡Ú    _put_connr"s r$Ú release_connzHTTPResponse.release_conns4€ØzŠz ×!1Ò!1Ø à 
‰
×јT×-Ñ-Ô.؈Õrcód—    |j«y#ttttf$rYywxYw)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)rlrÚ SocketErrorr
r r"s r$Ú
drain_connzHTTPResponse.drain_conns+€ð     Ø I‰IKøÜœ;¬ ´mÐDò    Ù ð    ús ‚“/®/cóp—|jr |jS|jr|jd¬«Sy)NT)Ú cache_content)rr€rlr"s r$r1zHTTPResponse.data%s2€ð :Š:Ø—:‘:Ð à 8Š8Ø—9‘9¨49Ó0Ð 0ð rcó—|jSr')r‡r"s r$r‘zHTTPResponse.connection.s€à×ÑÐrcó,—t|j«Sr')rr€r"s r$ÚisclosedzHTTPResponse.isclosed2s€Ü˜DŸH™HÓ%Ð%rcó—|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‚r"s r$ÚtellzHTTPResponse.tell5s€ð ×"Ñ"Ð"rcóú—|jjd«}|ˆ|jrtj    d«y    t |j d«Dcgc] }t|«‘Œc}«}t|«dkDrtd|z«‚|j«}|dkrd}        t|j«}|dvsd    |cxkrd
ksn|d k(rd}|Scc}w#t$rd}YŒBwxYw#t$rd}YŒ=wxYw) 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.rWrz8Content-Length contained multiple unmatching values (%s)r)éÌi0édéÈÚHEAD) rvr‰rrÚlogÚwarningÚsetrXÚintÚlenrÚpopÚ
ValueErrorrw)r#r’ÚlengthÚvalÚlengthsrws      r$r‹zHTTPResponse._init_length=s€ð—‘×!Ñ!Ð"2Ó3ˆà Р؏|Š|ô— ‘ ðôðð "ô °6·<±<ÀÓ3DÖE¨Cœs 3xÒEÓFÜw“< !Ò#Ü'ð1Ø39ñ:óðð!Ÿ™›ð˜A’:Ø!‘Fð    Ü˜Ÿ™Ó%ˆFð
ZÑ  3¨&Ô#6°3Ô#6¸.ÈFÒ:R؈Fàˆ ùò1Føôò Ø’ð ûôò    ØŠFð    ús6ÁCÁCÁ+3CÂ'C,ÃCà C)Ã(C)Ã, C:Ã9C:cóŒ—|jjdd«j«}|j€‰||jvrt |«|_yd|vre|j d«Dcgc].}|j«|jvr|j«‘Œ0}}t|«rt |«|_yyyycc}w)z=
        Set-up the _decoder attribute if necessary.
        úcontent-encodingrmNrW)    rvr‰rŠr~ÚCONTENT_DECODERSrYrXrZr°)r#Úcontent_encodingÚer•s    r$Ú _init_decoderzHTTPResponse._init_decoderqsÁ€ð  Ÿ<™<×+Ñ+Ð,>ÀÓC×IÑIÓKÐØ =‰=Ð  Ø 4×#8Ñ#8Ñ8Ü ,Ð-=Ó >• ØÐ(Ñ(ð.×3Ñ3°CÓ8öàØ—w‘w“y D×$9Ñ$9Ñ9ð—G‘G•I𐠠  ðô
y”>Ü$0Ð1AÓ$BD•Mð"ð )ð !ùòsÁ-3Ccó(—|s|S    |jr|jj|«}|r||j«z }|S#|j$r>}|jj    dd«j «}t d|z|«‚d}~wwxYw)zN
        Decode the data passed in and potentially flush the decoder.
        r·rmzEReceived response with content-encoding: %s, but failed to decode it.N)r~r/ÚDECODER_ERROR_CLASSESrvr‰rŠr Ú_flush_decoder)r#r1rtÚ flush_decoderrºr¹s      r$Ú_decodezHTTPResponse._decodeˆsŸ€ñ؈Kð        Ø}Š}Ø—}‘}×/Ñ/°Ó5ñ Ø D×'Ñ'Ó)Ñ )ˆDàˆ øð×)Ñ)ò    Ø#Ÿ|™|×/Ñ/Ð0BÀBÓG×MÑMÓOÐ Üð'Ø)9ñ:àóð ûð    ús†'AÁBÁ9B  BcóŒ—|jr8|jjd«}||jj«zSy)zk
        Flushes the decoder. Should only be called if the decoder is actually
        being used.
        r)r~r/rS)r#Úbufs  r$r¾zHTTPResponse._flush_decoderžs:€ð
=Š=Ø—-‘-×*Ñ*¨3Ó/ˆCؘŸ™×,Ñ,Ó.Ñ.Ð .àrc#óBK—d}        d–—d}|sL|jr|jj«|jr|jj«|jr,|jj«r|j«yyy#t$rt|jdd«‚t$r4}dt    |«vr t |«‚t|jdd«‚d}~wt tf$r}td|z|«‚d}~wwxYw#|sL|jr|jj«|jr|jj«|jr,|jj«r|j«wwwxYw­w)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)Ú SocketTimeoutrr†r
Ústrrr ržrrÚcloser‡r¤rœ)r#Ú
clean_exitrºs   r$Ú_error_catcherzHTTPResponse._error_catcher©s‚èø€ðˆ
ð+    $ð DÛð*ˆJñð×*Ò*Ø×+Ñ+×1Ñ1Ô3ð
×#Ò#Ø×$Ñ$×*Ñ*Ô,ð×&Ò&¨4×+BÑ+B×+KÑ+KÔ+MØ×!Ñ!Õ#ð,NÐ&øôM!ò Lô' t§z¡z°4Ð9JÓKÐKäò Là-´S¸³VÑ;ä" 1›+Ð%ä& t§z¡z°4Ð9JÓKÐKûä!¤;Ð/ò Dä#Ð$;¸aÑ$?ÀÓCÐCûð Dûñð×*Ò*Ø×+Ñ+×1Ñ1Ô3ð
×#Ò#Ø×$Ñ$×*Ñ*Ô,ð×&Ò&¨4×+BÑ+B×+KÑ+KÔ+MØ×!Ñ!Õ#ð,NÐ&üsF‚F‡B‹DBFÂ(DÂ</C+Ã+DÃ=D Ä DÄDÄBFÆFcóR—|jsJ‚d}|r||kDs|jrÎ|j|kDr¿tjs¯tjst
j dkrŒtj«}d}||dk7r_|t||«}||z}n|}|jj|«}|s    |j«S|j|«~|€ŒY|dk7rŒ_|j«S||jj|«S|jj«S)a_
        Read a response with the thought that reading the number of bytes
        larger than can fit in a 32-bit int at a time via SSL in some
        known cases leads to an overflow error that has to be prevented
        if `amt` or `self.length_remaining` indicate that a problem may
        happen.
 
        The known cases:
          * 3.8 <= CPython < 3.9.7 because of a bug
            https://github.com/urllib3/urllib3/issues/2513#issuecomment-1152559900.
          * urllib3 injected with pyOpenSSL-backed SSL-support.
          * CPython < 3.10 only when `amt` does not fit 32-bit int.
        iÿÿÿ)éé
ir) r€rŒrÚIS_SECURETRANSPORTÚ IS_PYOPENSSLÚsysÚ version_infoÚioÚBytesIOÚminrlÚwriteÚgetvalue)r#ÚamtÚ    c_int_maxÚbufferÚ max_chunk_amtÚ    chunk_amtr1s       r$Ú_fp_readzHTTPResponse._fp_readás €ðxŠxˆˆx؈    ñ˜˜yšØ×)Ò)¨d×.CÑ.CÀiÒ.Oä×+Ò+Ü×"Ò"¤c×&6Ñ&6¸Ò&@ä—Z‘Z“\ˆFð$ˆMؐ+ ¨¢Ø?Ü # C¨Ó 7Iؘ9Ñ$‘Cà -IØ—x‘x—}‘} YÓ/ÙØð—?‘?Ó$Ð $ð— ‘ ˜TÔ"Øð‘+ ¨£ð—?‘?Ó$Ð $ð*-¨4—8‘8—=‘= Ó%Ð M¸d¿h¹h¿m¹m»oÐ Mrcó–—|j«|€ |j}|j€yd}t|jdd«}|j    «5|s|j |«nd}|€d}n_d}|dk7rX|sV|jj «d}|jr.|jdvr t|j|j«‚ddd«rd|xjt|«z c_
|j|xjt|«zc_|j|||«}|r||_ |S#1swYŒqxYw)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.)
        NFÚclosedrTr)rN)r»rtr€r)rÈrÚrÆr|rŒrr‚r°rÀr)r#rÕrtr¡r¿Ú    fp_closedr1s       r$rlzHTTPResponse.reads=€ð*     ×ÑÔØ Ð !Ø!×0Ñ0ˆNà 8‰8Ð Ø àˆ Ü˜DŸH™H h°Ó6ˆ    à ×  Ñ  Ó "ñ    YÙ-64—=‘= Ô%¸CˆD؈{Ø $‘ à % à˜1’H¡Tð—H‘H—N‘NÔ$Ø$(MØ×2Ò2°t×7LÑ7LðUñ8ô-¨T×-@Ñ-@À$×BWÑBWÓXÐX÷7    Yñ: Ø × Ò ¤3 t£9Ñ ,Õ Ø×$Ñ$Ð0Ø×%Ò%¬¨T«Ñ2Õ%à—<‘<  n°mÓDˆDáØ!”
àˆ ÷O    Yð    Yús ÁA:D?Ä?Ec#óK—|jr-|j«r|j||¬«D]}|–—Œyt|j«s0|j ||¬«}|r|–—t|j«sŒ/yy­w)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.
        rs)rÕrtN)rrÚsupports_chunked_readsÚ read_chunkedrr€rl)r#rÕrtÚliner1s     r$ÚstreamzHTTPResponse.streamYstèø€ð  <Š<˜D×7Ñ7Ô9Ø×)Ñ)¨#¸nÐ)ÓMò Ø“
ñ ô# 4§8¡8Ô,Ø—y‘y S¸yÓHáØ’Jô    # 4§8¡8×,ùs ‚A=BÂBc ó2—|j}t|t«s?tjrtj
|«}nt|j ««}t|dd«}|d|||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``.
        rzr)rrvrwrxryrzrr7) rƒrur    rÚPY2Ú from_httplibÚitemsr)rwrxry)Ú ResponseClsÚrÚ response_kwrvrzÚresps      r$råzHTTPResponse.from_httplibss€ð—%‘%ˆä˜'¤>Ô2܏wŠwä(×5Ñ5°gÓ>‘ä(¨¯©«Ó9ô˜˜H aÓ(ˆÙð    
ØØØ—8‘8Ø—I‘IØ—8‘8ØØñ    
ðñ    
ˆðˆ rcóR—tjdtd¬«|jS)Nz|HTTPResponse.getheaders() is deprecated and will be removed in urllib3 v2.1.0. Instead access HTTPResponse.headers directly.r:©ÚcategoryÚ
stacklevel)ÚwarningsÚwarnÚDeprecationWarningrvr"s r$Ú
getheaderszHTTPResponse.getheaders”s&€Ü ‰ ð Oä'Øõ        
ð |‰|Ðrcór—tjdtd¬«|jj    ||«S)Nz‚HTTPResponse.getheader() is deprecated and will be removed in urllib3 v2.1.0. Instead use HTTPResponse.headers.get(name, default).r:rì)rïrðrñrvr‰)r#r+Údefaults   r$Ú    getheaderzHTTPResponse.getheaders3€Ü ‰ ð Vä'Øõ        
ð |‰|×Ñ  gÓ.Ð.rcó—|jSr')rvr"s r$ÚinfozHTTPResponse.info§s €Ø|‰|Ðrcóô—|js|jj«|jr|jj«|js t
j j|«yyr')rÜr€rÆr‡r}rÐÚIOBaser"s r$rÆzHTTPResponse.close«sN€Ø{Š{Ø H‰HN‰NÔ à × Ò Ø × Ñ × "Ñ "Ô $àŠÜ I‰IO‰O˜DÕ !ðrcó@—|js)tjjj    |«S|j
€yt |j
d«r|j
j«St |j
d«r|j
jSy)NTr¤rÜ)r}rÐrùrÜÚ__get__r€rPr¤r"s r$rÜzHTTPResponse.closedµsq€àŠÜ—9‘9×#Ñ#×+Ñ+¨DÓ1Ð 1Ø X‰XÐ ØÜ T—X‘X˜zÔ *Ø—8‘8×$Ñ$Ó&Ð &Ü T—X‘X˜xÔ (Ø—8‘8—?‘?Ð "àrcó¦—|j€ td«‚t|jd«r|jj«Std«‚)Nz-HTTPResponse has no file to get a fileno fromÚfilenozOThe file-like object this HTTPResponse is wrapped around has no file descriptor)r€ÚIOErrorrPrýr"s r$rýzHTTPResponse.filenoÂsI€Ø 8‰8Ð ÜÐIÓJÐ JÜ T—X‘X˜xÔ (Ø—8‘8—?‘?Ó$Ð $äð0óð rcó®—|jIt|jd«r2t|jdd«s|jj«Syyy)NrSrÜF)r€rPr)rSr"s r$rSzHTTPResponse.flushÍsJ€à H‰HÐ  Ü˜Ÿ™ 'Ô*ܘDŸH™H h°Ô6à—8‘8—>‘>Ó#Ð #ð7ð+ð !rcó—y)NTr7r"s r$ÚreadablezHTTPResponse.readableÕs€àrcó†—|jt|««}t|«dk(ry||dt|«t|«Sr_)rlr°)r#ÚbÚtemps   r$ÚreadintozHTTPResponse.readintoÙs;€ày‰yœ˜Q›Ó ˆÜ ˆt‹9˜Š>Øà!ˆAˆk”D“    ˆNܐt“9Ð rcó.—t|jd«S)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)rPr€r"s r$rßz#HTTPResponse.supports_chunked_readsâs€ôt—x‘x Ó&Ð&rcó—|jy|jjj«}|j    dd«d}    t |d«|_y#t $r|j«t||«‚wxYw)Nó;rrrB)    rˆr€rÚreadlinerXr¯r²rÆr)r#rás  r$Ú_update_chunk_lengthz!HTTPResponse._update_chunk_lengthëss€ð ?‰?Ð &Ø Øx‰x{‰{×#Ñ#Ó%ˆØz‰z˜$ Ó" 1Ñ%ˆð    1Ü! $¨›mˆDOøÜò    1à J‰JŒLÜ$ T¨4Ó0Ð 0ð    1ús ÁAÁ&BcóV—d}|€K|jj|j«}|}|jjd«d|_|S||jkr3|jj|«}|j|z
|_|}|S||jk(rA|jj|«}|jjd«d|_|}|S|jj|j«}|jjd«d|_|S)Nr:)r€Ú
_safe_readrˆ)r#rÕÚreturned_chunkÚchunkÚvalues     r$Ú _handle_chunkzHTTPResponse._handle_chunkùs
€ØˆØ ˆ;Ø—H‘H×'Ñ'¨¯©Ó8ˆEØ"ˆNØ H‰H× Ñ  Ô "Ø"ˆDŒOðÐð4—?‘?Ò "Ø—H‘H×'Ñ'¨Ó,ˆEØ"Ÿo™o°Ñ3ˆDŒOØ"ˆNðÐðD—O‘OÒ #Ø—H‘H×'Ñ'¨Ó,ˆEØ H‰H× Ñ  Ô "Ø"ˆDŒOØ"ˆNð
Ðð"ŸX™X×0Ñ0°·±ÓAˆNØ H‰H× Ñ  Ô "Ø"ˆDŒOØÐrc#óK—|j«|js td«‚|j«s t    d«‚|j «5|j r9t|j «r$|j j«    ddd«y|jj€
    ddd«y    |j«|jdk(rn,|j|«}|j||d¬«}|r|–—ŒL|r|j«}|r|–—    |jjj!«}|sn|dk(rnŒ.|j r|j j«ddd«y#1swYyxYw­w)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)rtr¿s
)r»rrrrßr rÈrrrÆr€rr rˆrrÀr¾r
)r#rÕrtrÚdecodedrás      r$ràzHTTPResponse.read_chunkedsˆèø€ð     ×ÑÔà|Š|Ü$ðBóð ð×*Ñ*Ô,Ü*ðPóð ð
×  Ñ  Ó "ñ)    0à×&Ò&Ô+>¸t×?VÑ?VÔ+WØ×'Ñ'×-Ñ-Ô/Ø÷    )    0ð)    0ðx‰x{‰{Ð"Ø÷)    0ð)    0ðØ×)Ñ)Ô+Ø—?‘? aÒ'ØØ×*Ñ*¨3Ó/ØŸ,™,ب.Èð'óñØ!’Mðñð×-Ñ-Ó/ÙØ!’MðØ—x‘x—{‘{×+Ñ+Ó-ÙàØ˜7’?Øð ð×&Ò&Ø×'Ñ'×-Ñ-Ô/÷S)    0÷)    0ñ)    0üs7‚AF
Á=E>    F
ÂE>Â2    F
Â;B:E>Å5    F
Å>FÆF
có¶—|jBt|jj«r#|jjdjS|jS)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.
        éÿÿÿÿ)r{r°ÚhistoryÚredirect_locationr„r"s r$ÚgeturlzHTTPResponse.geturlUsF€ð <‰<Ð #¬¨D¯L©L×,@Ñ,@Ô(AØ—<‘<×'Ñ'¨Ñ+×=Ñ=Ð =à×$Ñ$Ð $rc#ó.K—g}|jd¬«D]d}d|vrM|jd«}dj|«|dzdz–—|ddD]    }|dz–—Œ |dr|dg}ŒQg}ŒT|j|«Œf|rdj|«–—yy­w)NTrsó
rrrr)rârXÚjoinÚappend)r#r×rÚxs    r$Ú__iter__zHTTPResponse.__iter__`s±èø€ØˆØ—[‘[°[Ó5ò     %ˆEؘ‰~ØŸ ™  EÓ*Ø—h‘h˜vÓ&¨¨q©Ñ1°EÑ9Ò9ؘq ˜ò$Aؘe™)“Oð$à˜’9Ø# B™i˜[‘Fà‘Fà— ‘ ˜eÕ$ð     %ñ Ø—(‘(˜6Ó"Ó "ð ùs‚BB)rmNrrNrTTNNNNNFNNT)NNF)iNr')NN).r4r5r6rcr¸rNr˜r%r™rœrŸÚpropertyr1r‘r¤r¦r‹r»rþrrr½rÀr¾rrÈrÚrlrâÚ classmethodråròrõr÷rÆrÜrýrSrrrßr rràrrr7rr$ririsƒ„ñð@     Ð*ÐØ ÐØ˜T˜FÑ"ÐÚ1ÐðØØØØØØØØØ ØØ ØØ$ØØØó%ABòF ò ò    ðñ1óð1ðñ óð ò&ò#ò2òhCð&% d§j¡jÐ1ÐØ ÐØ &§,¡, Ñ0Ðòò,    ðñ5$óð5$òn.Nó`FóPð4ñóðò@ó/òò"ðñ
óð
ò    ò$òòò'ò 1òó,D0òL    %ó#rri)2Ú
__future__rrÐÚloggingrÎrïrÚ
contextlibrÚsocketrržrrÄrNrmrÚ _collectionsr    r‘r
r Ú
exceptionsr r rrrrrrrrÚpackagesrÚ util.responserrÚ    getLoggerr4r¬Úobjectrr9r?rLrUrYrùrir7rr$ú<module>r+sµðÝ&ã    ÛÛ
ÛÛ Ý%Ý'Ý+à     €åÝ(ß3÷ ÷ ÷ õß<à€g×јÓ!€ô"Vô"ô@vôô@&ô@ð<
Ðô˜ôô"6ôò*
ôR #2—9‘9õR #r