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
229
230
231
232
233
234
235
236
237
238
239
240
Ë
ñúhކãó—dZddlmZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlmZddlmZddlmZdd    lmZmZmZdd
lmZmZmZmZmZmZ    dd l    mZd dgZ#dZ$ejHZ%ejLjNZ(e jR«Z*e jV«Z,dZ-ej\ej^ej`ejbejdejfejhejjejlejnejpejrejtejvejxejzej|ej~ej€ej‚ej„ej†ejˆejŠejŒejŽejej’ej”ej–gZLejšejœejžfeejœejžfiZPeQe
d«r%ej¤ej¤fePe
j¦<eQe
d«r%ej¨ej¨fePe
jª<eQe
d«r%ejœejœfePe
j¬<eQe
d«r%ej®ej®fePe
j°<eQe
d«r%ejžejžfePe
j²<d„ZZd„Z[d„Z\d„Z]ej¼e\«Z_ejÀe]«ZaGd„deb«Zcerd d„Zdnd!d„Zdedec_dGd„deb«Zey#e $r dZdd l!m"Z"YŒ#wxYw)"aê    
SecureTranport support for urllib3 via ctypes.
 
This makes platform-native TLS available to urllib3 users on macOS without the
use of a compiler. This is an important feature because the Python Package
Index is moving to become a TLSv1.2-or-higher server, and the default OpenSSL
that ships with macOS is not capable of doing TLSv1.2. The only way to resolve
this is to give macOS users an alternative solution to the problem, and that
solution is to use SecureTransport.
 
We use ctypes here because this solution must not require a compiler. That's
because pip is not allowed to require a compiler either.
 
This is not intended to be a seriously long-term solution to this problem.
The hope is that PEP 543 will eventually solve this issue for us, at which
point we can retire this contrib module. But in the short term, we need to
solve the impending tire fire that is Python on Mac without this kind of
contrib module. So...here we are.
 
To use this module, simply import and inject it::
 
    import pip._vendor.urllib3.contrib.securetransport as securetransport
    securetransport.inject_into_urllib3()
 
Happy TLSing!
 
This code is a bastardised version of the code found in Will Bond's oscrypto
library. An enormous debt is owed to him for blazing this trail for us. For
that reason, this code should be considered to be covered both by urllib3's
license and by oscrypto's:
 
.. code-block::
 
    Copyright (c) 2015-2016 Will Bond <will@wbond.net>
 
    Permission is hereby granted, free of charge, to any person obtaining a
    copy of this software and associated documentation files (the "Software"),
    to deal in the Software without restriction, including without limitation
    the rights to use, copy, modify, merge, publish, distribute, sublicense,
    and/or sell copies of the Software, and to permit persons to whom the
    Software is furnished to do so, subject to the following conditions:
 
    The above copyright notice and this permission notice shall be included in
    all copies or substantial portions of the Software.
 
    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
    FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
    DEALINGS IN THE SOFTWARE.
é)Úabsolute_importNé)Úutil)Úsix)ÚPROTOCOL_TLS_CLIENTé)ÚCoreFoundationÚSecurityÚ SecurityConst)Ú_assert_no_errorÚ_build_tls_unknown_ca_alertÚ_cert_array_from_pemÚ_create_cfstring_arrayÚ_load_client_cert_chainÚ_temporary_keychain)Ú _fileobject©Úbackport_makefileÚinject_into_urllib3Úextract_from_urllib3Ti@ÚPROTOCOL_SSLv2ÚPROTOCOL_SSLv3ÚPROTOCOL_TLSv1ÚPROTOCOL_TLSv1_1ÚPROTOCOL_TLSv1_2cóä—tt_ttj_tt_ttj_dt_dtj_y)zG
    Monkey-patch urllib3 with SecureTransport-backed SSL-support.
    TN)ÚSecureTransportContextrÚ
SSLContextÚssl_ÚHAS_SNIÚIS_SECURETRANSPORT©óú^H:\Change_password\venv_build\Lib\site-packages\pip/_vendor/urllib3/contrib/securetransport.pyrr¼s>€ô-„D„OÜ1„D‡IIÔÜ„D„LÜ„D‡IIÔØ"„DÔØ#'„D‡IIÕ r#cóä—tt_ttj_tt_ttj_dt_dtj_y)z>
    Undo monkey-patching by :func:`inject_into_urllib3`.
    FN)Úorig_util_SSLContextrrrÚorig_util_HAS_SNIr r!r"r#r$rrÈs>€ô+„D„OÜ/„D‡IIÔÜ$„D„LÜ)„D‡IIÔØ#„DÔØ#(„D‡IIÕ r#có~—d}    tj|«}|€tjS|j}|d}|j «}d}d}    ||kr||dk\r:t j||«s$t    jtjd«‚||z
}    tj|    zj||z«}
|j|
|    «} || z }| s|stjSn||krŒ||d<||k7rtj&Sy#tj$rl} | j}|T|tjk7rA||d<|tj k(s|tj"k(rtj$cYd} ~ S‚Yd} ~ Œ•d} ~ wwxYw#t($r#} || |_tjcYd} ~ Sd} ~ wwxYw)zs
    SecureTransport read callback. This is called by ST to request that data
    be returned from the socket.
    Nrú    timed out)Ú_connection_refsÚgetr ÚerrSSLInternalÚsocketÚ
gettimeoutrÚ wait_for_readÚerrorÚerrnoÚEAGAINÚctypesÚc_charÚ from_addressÚ    recv_intoÚerrSSLClosedGracefulÚ
ECONNRESETÚEPIPEÚerrSSLClosedAbortÚerrSSLWouldBlockÚ    ExceptionÚ
_exception) Ú connection_idÚ data_bufferÚdata_length_pointerÚwrapped_socketÚ base_socketÚrequested_lengthÚtimeoutr0Ú
read_countÚ    remainingÚbufferÚ
chunk_sizeÚes              r$Ú_read_callbackrJÔs¹€ð
€Nð.,Ü)×-Ñ-¨mÓ<ˆØ Ð !Ü ×/Ñ/Ð /Ø$×+Ñ+ˆ à.¨qÑ1Ðà ×+Ñ+Ó-ˆØˆØˆ
ð    ØÐ/Ò/ؐ? g°¢lÜ×-Ñ-¨k¸7ÔCÜ$Ÿl™l¬5¯<©<¸ÓEÐEà,¨zÑ9    Ü Ÿ-™-¨)Ñ3×AÑAØ *Ñ,óð)×2Ñ2°6¸9ÓE
ؘjÑ(
Ù!Ù%Ü,×AÑAÐAØðÐ/Ó/ð0",ИAÑà Ð)Ò )Ü ×1Ñ1Ð 1àøô— ‘ ò    Ø—G‘GˆEàР U¬e¯l©lÒ%:Ø)3Ð# AÑ&ØœE×,Ñ,Ò,°¼¿¹Ò0DÜ(×:Ñ:Õ:Øÿøð    ûô ò,Ø Ð %Ø()ˆNÔ %Ü×+Ñ+Õ+ûð,úsf„&F«%FÁBDÃ,DÃ3FÄF Ä!AFÅ<F Å=FÆFÆFÆF Æ FÆ    F<ÆF7Æ1F<Æ7F<có4—d}    tj|«}|€tjS|j}|d}t j ||«}|j«}d}d}        |    |krb||dk\r:tj||«s$t    jtjd«‚|j|«}
|    |
z }    ||
d}|    |krŒb|    |d<|    |k7rtj"Sy#tj$rl} | j}|T|tjk7rA|    |d<|tjk(s|tjk(rtj cYd} ~ S‚Yd} ~ Œ•d} ~ wwxYw#t$$r#} || |_tjcYd} ~ Sd} ~ wwxYw)zx
    SecureTransport write callback. This is called by ST to request that data
    actually be sent on the network.
    Nrr))r*r+r r,r-r3Ú    string_atr.rÚwait_for_writer0r1r2Úsendr8r9r:r;r<r=) r>r?r@rArBÚbytes_to_writeÚdatarDr0ÚsentÚ
chunk_sentrIs             r$Ú_write_callbackrS s‘€ð
€Nð*,Ü)×-Ñ-¨mÓ<ˆØ Ð !Ü ×/Ñ/Ð /Ø$×+Ñ+ˆ à,¨QÑ/ˆÜ×Ñ  ¨^Ó<ˆà ×+Ñ+Ó-ˆØˆØˆð    Ø˜Ò'ؐ? g°¢lÜ×.Ñ.¨{¸GÔDÜ$Ÿl™l¬5¯<©<¸ÓEÐEØ(×-Ñ-¨dÓ3
ؘ
Ñ"ð˜J˜KÐ(ð˜Ó'ð&"&ИAÑà >Ò !Ü ×1Ñ1Ð 1àøô— ‘ ò    Ø—G‘GˆEàР U¬e¯l©lÒ%:Ø)-Ð# AÑ&ØœE×,Ñ,Ò,°¼¿¹Ò0DÜ(×:Ñ:Õ:Øÿøð    ûô ò,Ø Ð %Ø()ˆNÔ %Ü×+Ñ+Õ+ûð,ús`„&E+«;E+Á'A&C)ÃE+Ã)E(Ã<AE#ÅE(ÅE+ÅE#ÅE+Å#E(Å(E+Å+    FÅ4FÆ FÆFcó°—eZdZdZd„Zej d„«Zd„Zd„Z    d„Z
d„Z d„Z d    „Z d
„Zd „Zdd „Zd„Zd„Zd„Zd„Zd„Zd„Zdd„Zd„Zd„Zd„Zy )Ú WrappedSocketz²
    API-compatibility wrapper for Python's OpenSSL wrapped socket object.
 
    Note: _makefile_refs, _drop(), and _reuse() are needed for the garbage
    collector of PyPy.
    cóè—||_d|_d|_d|_d|_d|_d|_d|_|jj«|_    |jjd«y©NrF) r-ÚcontextÚ_makefile_refsÚ_closedr=Ú    _keychainÚ _keychain_dirÚ_client_cert_chainr.Ú_timeoutÚ
settimeout)Úselfr-s  r$Ú__init__zWrappedSocket.__init__Mse€ØˆŒ ؈Œ ØˆÔØˆŒ ؈ŒØˆŒØ!ˆÔØ"&ˆÔ🠙 ×.Ñ.Ó0ˆŒ Ø  ‰ ×јqÕ!r#c#ó†K—d|_d–—|j&|jdc}|_|j«|‚y­w)a]
        A context manager that can be used to wrap calls that do I/O from
        SecureTransport. If any of the I/O callbacks hit an exception, this
        context manager will correctly propagate the exception after the fact.
        This avoids silently swallowing those exceptions.
 
        It also correctly forces the socket closed.
        N)r=Úclose)r`Ú    exceptions  r$Ú_raise_on_errorzWrappedSocket._raise_on_error_sCèø€ðˆŒó
    Ø ?‰?Ð &Ø)-¯©¸$Ð &ˆIt”Ø J‰JŒL؈Oð 'ùs‚?Acó—tjtt«ztŽ}tj|j
|tt««}t |«y)a4
        Sets up the allowed ciphers. By default this matches the set in
        util.ssl_.DEFAULT_CIPHERS, at least as supported by macOS. This is done
        custom and doesn't allow changing at this time, mostly because parsing
        OpenSSL cipher strings is going to be a freaking nightmare.
        N)r
ÚSSLCipherSuiteÚlenÚ CIPHER_SUITESÚSSLSetEnabledCiphersrXr )r`ÚciphersÚresults   r$Ú _set_cipherszWrappedSocket._set_cipherstsH€ô×*Ñ*¬S´Ó-?Ñ?Ä-ÐPˆÜ×.Ñ.Ø L‰L˜'¤3¤}Ó#5ó
ˆô    ˜Õ r#có֗|syt|«}    tj|j|«}t    |«t j |«y#t j |«wxYw)z<
        Sets up the ALPN protocols on the context.
        N)rr
ÚSSLSetALPNProtocolsrXr r    Ú    CFRelease)r`Ú    protocolsÚ protocols_arrrls    r$Ú_set_alpn_protocolsz!WrappedSocket._set_alpn_protocolssT€ñØ Ü.¨yÓ9ˆ ð    4Ü×1Ñ1°$·,±,À ÓNˆFÜ ˜VÔ $ä × $Ñ $ ]Õ 3øŒN× $Ñ $ ]Õ 3ús +AÁA(có—|sytjtjf}    |j|«}||vryd|fz}t |j ««}|jj|«tjddd«}|jjtjtj|«|j«tj d|z«‚#t$r}d|›}Yd}~Œ¿d}~wwxYw)zþ
        Called when we have set custom validation. We do this in two cases:
        first, when cert validation is entirely disabled; and second, when
        using a custom trust DB.
        Raises an SSLError if the connection is not trusted.
        Nzerror code: %dz exception: Úiirrzcertificate verify failed, %s)r ÚkSecTrustResultUnspecifiedÚkSecTrustResultProceedÚ_evaluate_trustr<r Úversionr-ÚsendallÚstructÚpackÚ
setsockoptÚ
SOL_SOCKETÚ    SO_LINGERrcÚsslÚSSLError)    r`ÚverifyÚ trust_bundleÚ    successesÚ trust_resultÚreasonrIÚrecÚoptss             r$Ú_custom_validatezWrappedSocket._custom_validateŽsã€ñØ ô × 4Ñ 4Ü × 0Ñ 0ð
ˆ    ð    ,Ø×/Ñ/° Ó=ˆLؘyÑ(ØØ%¨¨Ñ7ˆFô *¨$¯,©,«.Ó9ˆØ  ‰ ×јCÔ ô{‰{˜4  AÓ&ˆØ  ‰ ×Ñœv×0Ñ0´&×2BÑ2BÀDÔIØ 
‰
Œ ܏l‰lÐ:¸VÑCÓDÐDøôó    ,á()Ð+Fûð    ,ús¥C-»C-Ã-    DÃ6DÄDcó‚—tjj|«r%t|d«5}|j    «}ddd«d}t j «}    t|«}t j|jtj|««}t|«|stjd«‚t j||«}t|«t j |d«}t|«t j"«}t j$|tj|««}t|«|rt'j(|«|t'j(|«|j*S#1swYŒExYw#|rt'j(|«|t'j(|«wwxYw)NÚrbzFailed to copy trust referenceT)ÚosÚpathÚisfileÚopenÚreadr
Ú SecTrustRefrÚSSLCopyPeerTrustrXr3Úbyrefr r€rÚSecTrustSetAnchorCertificatesÚ!SecTrustSetAnchorCertificatesOnlyÚSecTrustResultTypeÚSecTrustEvaluater    rpÚvalue)r`rƒÚfÚ
cert_arrayÚtrustrlr…s       r$rxzWrappedSocket._evaluate_trust±sb€ä 7‰7>‰>˜,Ô 'ܐl DÓ)ð (¨QØ Ÿv™v›x ÷ (ðˆ
Ü×$Ñ$Ó&ˆð    5ä-¨lÓ;ˆJô ×.Ñ.¨t¯|©|¼V¿\¹\È%Ó=PÓQˆFÜ ˜VÔ $ÙÜ—l‘lÐ#CÓDÐDä×;Ñ;¸EÀ:ÓNˆFÜ ˜VÔ $ä×?Ñ?ÀÀtÓLˆFÜ ˜VÔ $ä#×6Ñ6Ó8ˆLÜ×.Ñ.¨u´f·l±lÀ<Ó6PÓQˆFÜ ˜VÔ $áÜ×(Ñ(¨Ô/àÐ%Ü×(Ñ(¨Ô4à×!Ñ!Ð!÷G (ñ (ûñ:Ü×(Ñ(¨Ô/àÐ%Ü×(Ñ(¨Õ4ð&ús¬FÁC*F ÆF
Æ 1F>c
ó
—tjdtjtj«|_tj |j
tt«}
t|
«t5t|«dz} | tvr| dzdz} | tvrŒ|t| <ddd«tj|j
 «}
t|
«|rVt|t«s|j!d«}tj"|j
|t%|««}
t|
«|j'«|j)|    «tj*|j
|«}
t|
«tj,|j
|«}
t|
«|r|:tj.|j
tj0d«}
t|
«|rht3«\|_|_t9|j4||«|_tj<|j
|j:«}
t|
«    |j?«5tj@|j
«}
|
tjBk(rtEjFd«‚|
tjHk(r|jK||«    ddd«Œˆt|
«    ddd«y#1swYŒIxYw#1swYnxYwŒ¶)z‘
        Actually performs the TLS handshake. This is run automatically by
        wrapped socket, and shouldn't be needed in user code.
        Niÿÿÿrzutf-8Tzhandshake timed out)&r
ÚSSLCreateContextr ÚkSSLClientSideÚkSSLStreamTyperXÚ SSLSetIOFuncsÚ_read_callback_pointerÚ_write_callback_pointerr Ú_connection_ref_lockÚidr*ÚSSLSetConnectionÚ
isinstanceÚbytesÚencodeÚSSLSetPeerDomainNamerhrmrsÚSSLSetProtocolVersionMinÚSSLSetProtocolVersionMaxÚSSLSetSessionOptionÚ"kSSLSessionOptionBreakOnServerAuthrr[r\rr]ÚSSLSetCertificatereÚ SSLHandshaker;r-rDÚerrSSLServerAuthCompletedr‰) r`Úserver_hostnamer‚rƒÚ min_versionÚ max_versionÚ client_certÚ
client_keyÚclient_key_passphraseÚalpn_protocolsrlÚhandles             r$Ú    handshakezWrappedSocket.handshakeÙs‘€ô$ ×0Ñ0Ø ”-×.Ñ.´ ×0LÑ0Ló
ˆŒ ô×'Ñ'Ø L‰LÔ0Ô2Ió
ˆô    ˜Ô ô
"ñ    ,ܘ“X 
Ñ*ˆFØÔ,Ñ,Ø  1™*¨
Ñ2ðÔ,Ò,à'+Ô ˜VÑ $÷        ,ô ×*Ñ*¨4¯<©<¸Ó@ˆÜ˜Ô ñ ܘo¬uÔ5Ø"1×"8Ñ"8¸Ó"Aä×2Ñ2Ø— ‘ ˜o¬s°?Ó/CóˆFô ˜VÔ $ð     ×ÑÔð     × Ñ  Ô0ô×2Ñ2°4·<±<ÀÓMˆÜ˜Ô ä×2Ñ2°4·<±<ÀÓMˆÜ˜Ô ñ ˜Ð1Ü×1Ñ1Ø— ‘ œm×NÑNÐPTóˆFô ˜VÔ $ñ Ü1DÓ1FÑ .ˆDŒN˜DÔ.Ü&=Ø—‘  ¨Zó'ˆDÔ #ô×/Ñ/°· ± ¸d×>UÑ>UÓVˆFÜ ˜VÔ $àØ×%Ñ%Ó'ñ
Ü!×.Ñ.¨t¯|©|Ó<àœ]×;Ñ;Ò;Ü Ÿ.™.Ð)>Ó?Ð?Øœ}×FÑFÒFØ×)Ñ)¨&°,Ô?Ø÷
ô% VÔ,Ø÷
÷i    ,ñ    ,ú÷h
úðs%Á3'K+    K+ÉA.K8Ë K8Ë+K5Ë8Lcó6—|jj«S©N)r-Úfileno©r`s r$r¼zWrappedSocket.fileno6s€Ø{‰{×!Ñ!Ó#Ð#r#có†—|jdkDr|xjdzc_|jr|j«yy)Nrr)rYrZrcr½s r$Ú_decref_socketioszWrappedSocket._decref_socketios:s6€Ø × Ñ  Ò "Ø × Ò  1Ñ $Õ Ø <Š<Ø J‰JLð r#có^—tj|«}|j||«}|d|}|Sr»)r3Úcreate_string_bufferr6)r`ÚbufsizrGÚ
bytes_readrPs     r$ÚrecvzWrappedSocket.recv@s3€Ü×,Ñ,¨VÓ4ˆØ—^‘^ F¨FÓ3ˆ
ؐkzÐ"ˆØˆ r#Nc    óˆ—|jry|€ t|«}tj|zj    |«}tj
d«}|j «5tj|j||tj|««}ddd«tjk(r0|jdk(rtjd«‚|jS|tj tj"fvr|j%«|jSt'|«|jS#1swYŒ¡xYw)Nrzrecv timed out)rZrhr3r4Ú from_bufferÚc_size_trer
ÚSSLReadrXr“r r;r˜r-rDr7ÚerrSSLClosedNoNotifyrcr )r`rGÚnbytesÚprocessed_bytesrls     r$r6zWrappedSocket.recv_intoFs€à <Š<Øà ˆ>ܘ“[ˆFä—-‘- &Ñ(×5Ñ5°fÓ=ˆÜ Ÿ/™/¨!Ó,ˆà × !Ñ !Ó #ñ    Ü×%Ñ%Ø— ‘ ˜f f¬f¯l©l¸?Ó.KóˆF÷    ð ”]×3Ñ3Ò 3ð
×$Ñ$¨Ò)ä—n‘nÐ%5Ó6Ð6ð×$Ñ$Ð$ðÜ × .Ñ .Ü × .Ñ .ð
ñ
ð J‰JŒLð ×$Ñ$Ð$ô     ˜VÔ $ð×$Ñ$Ð$÷=    ð    ús Á"6D8Ä8Ecó—||_yr»©r^)r`rDs  r$r_zWrappedSocket.settimeoutqs    €Øˆ r#có—|jSr»rÍr½s r$r.zWrappedSocket.gettimeoutts €Ø}‰}Ðr#c    óŽ—tjd«}|j«5tj|j
|t |«tj|««}ddd«tjk(r$|jdk(rtjd«‚t|«|jS#1swYŒWxYw)Nrzsend timed out)r3rÇrer
ÚSSLWriterXrhr“r r;r˜r-rDr )r`rPrËrls    r$rNzWrappedSocket.sendwsŸ€Ü Ÿ/™/¨!Ó,ˆà × !Ñ !Ó #ñ    Ü×&Ñ&Ø— ‘ ˜d¤C¨£I¬v¯|©|¸OÓ/LóˆF÷    ð
”]×3Ñ3Ò 3¸×8MÑ8MÐQRÒ8Rä—.‘.Ð!1Ó2Ð 2ä ˜VÔ $ð×$Ñ$Ð$÷    ð    ús ¦?B;Â;Ccó„—d}|t|«kr0|j|||tz«}||z }|t|«krŒ/yy©Nr)rhrNÚSSL_WRITE_BLOCKSIZE)r`rPÚ
total_sentrQs    r$rzzWrappedSocket.sendallˆsF€Øˆ
Øœ3˜t›9Ò$Ø—9‘9˜T *¨zÔ<OÑ/OÐPÓQˆDØ ˜$Ñ ˆJðœ3˜t›9Õ$r#cóŒ—|j«5tj|j«ddd«y#1swYyxYwr»)rer
ÚSSLCloserXr½s r$ÚshutdownzWrappedSocket.shutdownŽs5€Ø × !Ñ !Ó #ñ    ,Ü × Ñ ˜dŸl™lÔ +÷    ,÷    ,ñ    ,ús    ‘ :ºAcóD—|jdkrüd|_|jr&tj|j«d|_|j
r&tj|j
«d|_|j rktj|j «tj|j «tj|j«dx|_|_ |jj«S|xjdzc_y)NrT)rYrZrXr    rpr]r[r
ÚSecKeychainDeleteÚshutilÚrmtreer\r-rcr½s r$rczWrappedSocket.close’s̀à × Ñ  Ò "؈DŒL؏|Š|Ü×(Ñ(¨¯©Ô6Ø#” Ø×&Ò&Ü×(Ñ(¨×)@Ñ)@ÔAØ*.Ô'؏~Š~Ü×*Ñ*¨4¯>©>Ô:Ü×(Ñ(¨¯©Ô8Ü— ‘ ˜d×0Ñ0Ô1Ø6:Ð:” Ô!3Ø—;‘;×$Ñ$Ó&Ð &à × Ò  1Ñ $Ö r#cón—|s td«‚tj«}d}d}    tj|jt j |««}t|«|s1    |rtj|«|rtj|«yytj|«}|s1    |rtj|«|rtj|«yytj|d«}|sJ‚tj|«}|sJ‚tj|«}tj|«}    t j|    |«}|rtj|«|rtj|«|S#|rtj|«|rtj|«wwxYw)Nz2SecureTransport only supports dumping binary certsr)Ú
ValueErrorr
r‘r’rXr3r“r r    rpÚSecTrustGetCertificateCountÚSecTrustGetCertificateAtIndexÚSecCertificateCopyDataÚCFDataGetLengthÚCFDataGetBytePtrrL)
r`Ú binary_formr›ÚcertdataÚ    der_bytesrlÚ
cert_countÚleafÚ data_lengthr?s
          r$Ú getpeercertzWrappedSocket.getpeercert¥s‚€ñ(ÜÐQÓRÐ RÜ×$Ñ$Ó&ˆØˆØˆ    ð    0ä×.Ñ.¨t¯|©|¼V¿\¹\È%Ó=PÓQˆFÜ ˜VÔ $Ùàñ&Ü×(Ñ(¨Ô2ÙÜ×(Ñ(¨Õ/ðô'"×=Ñ=¸eÓDˆJÙðñÜ×(Ñ(¨Ô2ÙÜ×(Ñ(¨Õ/ðô×9Ñ9¸%ÀÓCˆDÙˆK4ô ×6Ñ6°tÓ<ˆHÙˆO8ä(×8Ñ8¸ÓBˆKÜ(×9Ñ9¸(ÓCˆKÜ×(Ñ(¨°kÓBˆIáÜ×(Ñ(¨Ô2ÙÜ×(Ñ(¨Ô/àÐøñ Ü×(Ñ(¨Ô2ÙÜ×(Ñ(¨Õ/ðús§AFÂFàA3FÆ1F4cóf—tj«}tj|jt    j
|««}t |«|jtjk(rtjd«‚|jtjk(ry|jtjk(ry|jtjk(ry|jtjk(ry|jtj k(rytjd|z«‚)Nz(SecureTransport does not support TLS 1.3zTLSv1.2zTLSv1.1ÚTLSv1ÚSSLv3ÚSSLv2zUnknown TLS version: %r)r
Ú SSLProtocolÚSSLGetNegotiatedProtocolVersionrXr3r“r r˜r ÚkTLSProtocol13r€rÚkTLSProtocol12ÚkTLSProtocol11Ú kTLSProtocol1Ú kSSLProtocol3Ú kSSLProtocol2)r`Úprotocolrls   r$ryzWrappedSocket.versionßs܀Ü×'Ñ'Ó)ˆÜ×9Ñ9Ø L‰Lœ&Ÿ,™, xÓ0ó
ˆô    ˜Ô Ø >‰>œ]×9Ñ9Ò 9Ü—,‘,ÐIÓJÐ JØ ^‰^œ}×;Ñ;Ò ;ØØ ^‰^œ}×;Ñ;Ò ;ØØ ^‰^œ}×:Ñ:Ò :ØØ ^‰^œ}×:Ñ:Ò :ØØ ^‰^œ}×:Ñ:Ò :Øä—,‘,Ð8¸8ÑCÓDÐ Dr#có.—|xjdz c_y©Nr)rYr½s r$Ú_reusezWrappedSocket._reuseôs€Ø ×Ò˜qÑ Ör#cón—|jdkr|j«y|xjdzc_yrø)rYrcr½s r$Ú_dropzWrappedSocket._drop÷s*€Ø × Ñ  Ò "Ø J‰JLà × Ò  1Ñ $Ö r#r»)F)Ú__name__Ú
__module__Ú __qualname__Ú__doc__raÚ
contextlibÚcontextmanagerrermrsr‰rxr¹r¼r¿rÄr6r_r.rNrzr×rcréryrùrûr"r#r$rUrUEs„ñò"ð$×Ññóðò( !ò 4ò!EòF&"òP[òz$òò ó )%òV òò%ò"ò ,ò%ó&8òtEò*!ó%r#rUcóJ—|xjdz c_t|||d¬«S)NrT)rc)rYr)r`ÚmodeÚbufsizes   r$Úmakefilers$€Ø ×Ò˜qÑ Õܘ4  w°dÔ;Ð;r#có(—d}t|||g|¢­i|¤ŽSrÒr)r`rÚ    bufferingÚargsÚkwargss     r$rrs"€ðˆ    Ü   t¨YÐH¸ÒHÀÑHÐHr#cóê—eZdZdZd„Zed„«Zejd„«Zed„«Zejd„«Zed„«Z    e    jd„«Z    d    „Z
d
„Z d „Z dd „Z dd„Zd„Z                dd„Zy )rz¯
    I am a wrapper class for the SecureTransport library, to translate the
    interface of the standard library ``SSLContext`` object to calls into
    SecureTransport.
    có’—t|\|_|_d|_d|_d|_d|_d|_d|_d|_    yrW)
Ú_protocol_to_min_maxÚ _min_versionÚ _max_versionÚ_optionsÚ_verifyÚ _trust_bundleÚ _client_certÚ _client_keyÚ_client_key_passphraseÚ_alpn_protocols)r`rös  r$razSecureTransportContext.__init__sM€Ü/CÀHÑ/MÑ,ˆÔ˜4Ô,؈Œ ؈Œ Ø!ˆÔØ ˆÔØˆÔØ&*ˆÔ#Ø#ˆÕr#có—y)úŽ
        SecureTransport cannot have its hostname checking disabled. For more,
        see the comment on getpeercert() in this file.
        Tr"r½s r$Úcheck_hostnamez%SecureTransportContext.check_hostname!s€ð r#có—y)rNr"©r`r˜s  r$rz%SecureTransportContext.check_hostname)s€ð      r#có—|jSr»©rr½s r$ÚoptionszSecureTransportContext.options1s€ð}‰}Ðr#có—||_yr»rrs  r$rzSecureTransportContext.options;s €ðˆ r#cóZ—|jrtjStjSr»)rr€Ú CERT_REQUIREDÚ    CERT_NONEr½s r$Ú verify_modez"SecureTransportContext.verify_mode@s€à$(§L¢LŒs× Ñ ÐC´c·m±mÐCr#cóH—|tjk(rd|_yd|_y)NTF)r€r rrs  r$r"z"SecureTransportContext.verify_modeDs€à$¬×(9Ñ(9Ò9tˆ ¸uˆ r#có—yr»r"r½s r$Úset_default_verify_pathsz/SecureTransportContext.set_default_verify_pathsHs€ð     r#có"—|j«Sr»)r%r½s r$Úload_default_certsz)SecureTransportContext.load_default_certsTs€Ø×,Ñ,Ó.Ð.r#cóT—|tjjk7r td«‚y)Nz5SecureTransport doesn't support custom cipher strings)rrÚDEFAULT_CIPHERSrÝ)r`rks  r$Ú set_ciphersz"SecureTransportContext.set_ciphersWs%€à ”d—i‘i×/Ñ/Ò /ÜÐTÓUÐ Uð 0r#Ncóz—| td«‚|t|«5    ddd«|xs||_y#1swYŒxYw)Nz1SecureTransport does not support cert directories)rÝrr)r`ÚcafileÚcapathÚcadatas    r$Úload_verify_locationsz,SecureTransportContext.load_verify_locations\sJ€à Ð ÜÐPÓQÐ Qð Рܐf“ñ Ø÷ ð$Ò- vˆÕ÷ ð ús›1±:có.—||_||_||_yr»)rrÚ_client_cert_passphrase)r`ÚcertfileÚkeyfileÚpasswords    r$Úload_cert_chainz&SecureTransportContext.load_cert_chainhs€Ø$ˆÔØ"ˆÔØ'/ˆÕ$r#có”—ttd«s td«‚|Dcgc]}tj|«‘Œc}|_ycc}w)z
        Sets the ALPN protocols that will later be set on the context.
 
        Raises a NotImplementedError if ALPN is not supported.
        roz2SecureTransport supports ALPN only in macOS 10.12+N)Úhasattrr
ÚNotImplementedErrorrÚ ensure_binaryr)r`rqÚps   r$Úset_alpn_protocolsz)SecureTransportContext.set_alpn_protocolsmsC€ô ”xÐ!6Ô7Ü%ØDóð ð?HÖH¸¤× 1Ñ 1°!Õ 4ÒHˆÕùÒHs Ac ó—|rJ‚|sJ‚|sJ‚t|«}|j||j|j|j|j
|j |j|j|j«    |Sr»)
rUr¹rrr rrrrr)r`ÚsockÚ server_sideÚdo_handshake_on_connectÚsuppress_ragged_eofsr±rAs       r$Ú wrap_socketz"SecureTransportContext.wrap_socketys‹€ñЈÙ&Ð&Ð&Ù#Ð#Ð#ô' tÓ,ˆð    × Ñ Ø Ø L‰LØ × Ñ Ø × Ñ Ø × Ñ Ø × Ñ Ø × Ñ Ø × 'Ñ 'Ø ×  Ñ  ô
    
ðÐr#)NNN)NN)FTTN)rürýrþrÿraÚpropertyrÚsetterrr"r%r'r*r/r5r;rAr"r#r$rrs˄ñò $ðñóðð×Ññ óð ðñóðð ‡^^ñóððñDóðDð×ÑñEóðEò
 ò/òVó
 
.ó0ò
 
IðØ $Ø!Øô r#r)éÿÿÿÿ)ÚrN)frÿÚ
__future__rrr3r1Úos.pathrŒrÚr-r€r{Ú    threadingÚweakrefÚrÚpackagesrÚ    util.ssl_rÚ_securetransport.bindingsr    r
r Ú_securetransport.low_levelr r rrrrrÚ ImportErrorÚpackages.backports.makefilerÚ__all__r r'rrr&ÚWeakValueDictionaryr*ÚLockr£rÓÚ'TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384Ú'TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256Ú%TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384Ú%TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256Ú-TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256Ú+TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256Ú#TLS_DHE_RSA_WITH_AES_256_GCM_SHA384Ú#TLS_DHE_RSA_WITH_AES_128_GCM_SHA256Ú'TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384Ú$TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHAÚ'TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256Ú$TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHAÚ%TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384Ú"TLS_ECDHE_RSA_WITH_AES_256_CBC_SHAÚ%TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256Ú"TLS_ECDHE_RSA_WITH_AES_128_CBC_SHAÚ#TLS_DHE_RSA_WITH_AES_256_CBC_SHA256Ú TLS_DHE_RSA_WITH_AES_256_CBC_SHAÚ#TLS_DHE_RSA_WITH_AES_128_CBC_SHA256Ú TLS_DHE_RSA_WITH_AES_128_CBC_SHAÚTLS_AES_256_GCM_SHA384ÚTLS_AES_128_GCM_SHA256ÚTLS_RSA_WITH_AES_256_GCM_SHA384ÚTLS_RSA_WITH_AES_128_GCM_SHA256ÚTLS_AES_128_CCM_8_SHA256ÚTLS_AES_128_CCM_SHA256ÚTLS_RSA_WITH_AES_256_CBC_SHA256ÚTLS_RSA_WITH_AES_128_CBC_SHA256ÚTLS_RSA_WITH_AES_256_CBC_SHAÚTLS_RSA_WITH_AES_128_CBC_SHAriÚ PROTOCOL_TLSrórñr r7rõrrôrrròrrrrrJrSÚ SSLReadFuncr¡Ú SSLWriteFuncr¢ÚobjectrUrrr"r#r$ú<module>rvsŠðñ4õj'ãÛ Û ÛÛ Û Û
Û ÛÛåÝÝ+ßNÑN÷÷ð@Ý"ð
!Ð"8Ð
9€ð €à—L‘LÐØ—y‘y×+Ñ+Ðð$/7×.Ñ.Ó0ÐØ%y—~‘~Ó'ÐðÐð ×9Ñ9Ø×9Ñ9Ø×7Ñ7Ø×7Ñ7Ø×?Ñ?Ø×=Ñ=Ø×5Ñ5Ø×5Ñ5Ø×9Ñ9Ø×6Ñ6Ø×9Ñ9Ø×6Ñ6Ø×7Ñ7Ø×4Ñ4Ø×7Ñ7Ø×4Ñ4Ø×5Ñ5Ø×2Ñ2Ø×5Ñ5Ø×2Ñ2Ø×(Ñ(Ø×(Ñ(Ø×1Ñ1Ø×1Ñ1Ø×*Ñ*Ø×(Ñ(Ø×1Ñ1Ø×1Ñ1Ø×.Ñ.Ø×.Ñ.ð=€ ðJ    ×ј ×3Ñ3°]×5QÑ5QÐRؘ-×5Ñ5°}×7SÑ7SÐTðÐñ
 ˆ3РÔ!à×#Ñ#Ø×#Ñ#ð0И×+Ñ+Ñ,ñ ˆ3РÔ!à×#Ñ#Ø×#Ñ#ð0И×+Ñ+Ñ,ñ ˆ3РÔ!à×#Ñ#Ø×#Ñ#ð0И×+Ñ+Ñ,ñ ˆ3Ð"Ô#à×$Ñ$Ø×$Ñ$ð2И×-Ñ-Ñ.ñ ˆ3Ð"Ô#à×$Ñ$Ø×$Ñ$ð2И×-Ñ-Ñ.ò     (ò    )ò4,òn0,ðl.˜×-Ñ-¨nÓ=ÐØ/˜(×/Ñ/°Ó@Ðôv%Fôv%ñr ô<ó Ið"€ ÔôH˜VõHøð}ò@Ø€Kß?Ð?ð@úsÁM7Í7 NÎN