HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /lib/python3/dist-packages/urllib3/contrib/__pycache__/
Upload File :
Current File : //lib/python3/dist-packages/urllib3/contrib/__pycache__/securetransport.cpython-311.pyc
�

-�cp����dZddlmZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddl
Z
ddlZddlmZddlmZddlmZmZmZdd	lmZmZmZmZmZmZ	dd
l	mZn#e$rdZddl m!Z!YnwxYwdd
gZ"dZ#ej#Z$ej%j&Z'e
j(��Z)ej*��Z+dZ,ej-ej.ej/ej0ej1ej2ej3ej4ej5ej6ej7ej8ej9ej:ej;ej<ej=ej>ej?ej@ejAejBejCejDejEejFejGejHejIejJgZKejLejMejNfeejMejNfiZOePe
d��rejQejQfeOe
jR<ePe
d��rejSejSfeOe
jT<ePe
d��rejMejMfeOe
jU<ePe
d��rejVejVfeOe
jW<ePe
d��rejNejNfeOe
jX<d�ZYd�ZZd�Z[d�Z\ej]e[��Z^ej_e\��Z`Gd�dea��Zberd!d�Zcnd"d�Zceceb_cGd�d ea��ZddS)#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 urllib3.contrib.securetransport
    urllib3.contrib.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)�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_dS)zG
    Monkey-patch urllib3 with SecureTransport-backed SSL-support.
    TN)�SecureTransportContextr�
SSLContext�ssl_�HAS_SNI�IS_SECURETRANSPORT���A/usr/lib/python3/dist-packages/urllib3/contrib/securetransport.pyrr�s>��-�D�O�1�D�I���D�L��D�I��"�D��#'�D�I� � � r"c���tt_ttj_tt_ttj_dt_dtj_dS)z>
    Undo monkey-patching by :func:`inject_into_urllib3`.
    FN)�orig_util_SSLContextrrr�orig_util_HAS_SNIrr r!r"r#rr�s>��+�D�O�/�D�I��$�D�L�)�D�I��#�D��#(�D�I� � � r"c�H�d}	t�|��}|�tjS|j}|d}|���}d}d}	||kr�|�|dkr4t
j||��st	jtj
d���||z
}	tj|	z�
||z��}
|�|
|	��}||z
}|s|stjSn||k��nl#tj$rZ}|j	}|�G|tj
kr7||d<|tjks|tjkrtjcYd}~S�Yd}~nd}~wwxYw||d<||krtjSdS#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�timeoutr/�
read_count�	remaining�buffer�
chunk_size�es
             r#�_read_callbackrI�s��
�N�.,�)�-�-�m�<�<���!� �/�/�$�+��.�q�1�� �+�+�-�-�����
�	��/�/�/��?�g��l�l��-�k�7�C�C�F�$�l�5�<��E�E�E�,�z�9�	� �-�)�3�A�A��*�,����)�2�2�6�9�E�E�
��j�(�
�!��%�B�,�A�A���/�/�/�����	�	�	��G�E�� �U�e�l�%:�%:�)3�#�A�&��E�,�,�,����0D�0D�(�:�:�:�:�:�:�:�����������	����",��A���)�)�)� �1�1��q���,�,�,��%�()�N�%��+�+�+�+�+�+�+�����,���sf�'E8�'E8�BC3�+C3�2E8�3E�A	E�E�E8�E�E8�E�E8�8
F!�F�F!�F!c��d}	t�|��}|�tjS|j}|d}tj||��}|���}d}d}		|	|krf|�|dkr4tj	||��st	j
tjd���|�
|��}
|	|
z
}	||
d�}|	|k�fnl#tj
$rZ}|j}|�G|tjkr7|	|d<|tjks|tjkrtjcYd}~S�Yd}~nd}~wwxYw|	|d<|	|krtjSdS#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,r2�	string_atr-r�wait_for_writer/r0r1�sendr7r8r9r:r;r<)r=r>r?r@rA�bytes_to_write�datarCr/�sent�
chunk_sentrHs            r#�_write_callbackrRs���
�N�*,�)�-�-�m�<�<���!� �/�/�$�+��,�Q�/�����^�<�<�� �+�+�-�-������	���'�'��?�g��l�l��.�{�G�D�D�F�$�l�5�<��E�E�E�(�-�-�d�3�3�
��
�"���J�K�K�(����'�'�����	�	�	��G�E�� �U�e�l�%:�%:�)-�#�A�&��E�,�,�,����0D�0D�(�:�:�:�:�:�:�:�����������	����"&��A���>�!�!� �1�1��q���,�,�,��%�()�N�%��+�+�+�+�+�+�+�����,���s`�'E�<E�)A,C�E�D?�%A	D:�.D?�/E�4D:�5E�:D?�?E�
F�%E?�9F�?Fc��eZdZdZd�Zejd���Zd�Zd�Z	d�Z
d�Zd�Zd	�Z
d
�Zd�Zdd
�Zd�Zd�Zd�Zd�Zd�Zd�Zdd�Zd�Zd�Zd�ZdS)�
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|_|j���|_	|j�
d��dS�NrF)r,�context�_makefile_refs�_closedr<�	_keychain�
_keychain_dir�_client_cert_chainr-�_timeout�
settimeout)�selfr,s  r#�__init__zWrappedSocket.__init__Nsp��������������������!���"&�����.�.�0�0��
�����q�!�!�!�!�!r"c#�xK�d|_dV�|j�%|jdc}|_|���|�dS)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`sL�������
	�����?�&�)-��$�&�I�t���J�J�L�L�L��O�'�&r"c���tjtt��zt�}tj|j|tt����}t
|��dS)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�SSLSetEnabledCiphersrWr)r_�ciphers�results   r#�_set_cipherszWrappedSocket._set_ciphersusW���*�S��-?�-?�?�-�P���.��L�'�3�}�#5�#5�
�
��	�� � � � � r"c���|sdSt|��}	tj|j|��}t	|��tj|��dS#tj|��wxYw)z<
        Sets up the ALPN protocols on the context.
        N)rr	�SSLSetALPNProtocolsrWrr�	CFRelease)r_�	protocols�
protocols_arrrks    r#�_set_alpn_protocolsz!WrappedSocket._set_alpn_protocols�ss���	��F�.�y�9�9�
�	4��1�$�,�
�N�N�F��V�$�$�$��$�]�3�3�3�3�3��N�$�]�3�3�3�3���s�)A�A*c��|sdStjtjf}	|�|��}||vrdSd|fz}n#t$r}d|��}Yd}~nd}~wwxYwt|�����}|j�|��tj
ddd��}|j�tjtj
|��|���tjd|z���)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: %dzexception: �iirrzcertificate verify failed, %s)r
�kSecTrustResultUnspecified�kSecTrustResultProceed�_evaluate_trustr;r�versionr,�sendall�struct�pack�
setsockopt�
SOL_SOCKET�	SO_LINGERrb�ssl�SSLError)	r_�verify�trust_bundle�	successes�trust_result�reasonrH�rec�optss	         r#�_custom_validatezWrappedSocket._custom_validate�s���	��F�
�4��0�
�	�	,��/�/��=�=�L��y�(�(���%���7�F�F���	,�	,�	,�	,�()��+�F�F�F�F�F�F�����	,����
*�$�,�,�.�.�9�9������C� � � ��{�4��A�&�&������v�0�&�2B�D�I�I�I��
�
�����l�:�V�C�D�D�Ds�A�A�
A�
A�Ac��tj�|��r<t|d��5}|���}ddd��n#1swxYwYd}tj��}	t|��}tj|j	tj|����}t|��|stjd���tj||��}t|��tj|d��}t|��tj��}tj|tj|����}t|��|rt'j|��|�t'j|��n2#|rt'j|��|�t'j|��wwxYw|jS)N�rbzFailed to copy trust referenceT)�os�path�isfile�open�readr	�SecTrustRefr
�SSLCopyPeerTrustrWr2�byrefrrr��SecTrustSetAnchorCertificates�!SecTrustSetAnchorCertificatesOnly�SecTrustResultType�SecTrustEvaluaterro�value)r_r��f�
cert_array�trustrkr�s       r#rwzWrappedSocket._evaluate_trust�s���
�7�>�>�,�'�'�	(��l�D�)�)�
(�Q� �v�v�x�x��
(�
(�
(�
(�
(�
(�
(�
(�
(�
(�
(����
(�
(�
(�
(��
��$�&�&��	5�-�l�;�;�J��.�t�|�V�\�%�=P�=P�Q�Q�F��V�$�$�$��
E��l�#C�D�D�D��;�E�:�N�N�F��V�$�$�$��?��t�L�L�F��V�$�$�$�#�6�8�8�L��.�u�f�l�<�6P�6P�Q�Q�F��V�$�$�$��
0��(��/�/�/��%��(��4�4�4���	�
0��(��/�/�/��%��(��4�4�4�4�&�����!�!s�A�A�A�2C1F�/F?c
��tjdtjtj��|_tj|jtt��}
t|
��t5t|��dz}|tvr|dzdz}|tv�|t|<ddd��n#1swxYwYtj
|j|��}
t|
��|rat|t��s|�d��}tj|j|t%|����}
t|
��|���|�|	��tj|j|��}
t|
��tj|j|��}
t|
��|r|�4tj|jtjd��}
t|
��|rdt3��\|_|_t9|j||��|_tj|j|j��}
t|
��	|���5tj |j��}
|
tj!krtEj#d���|
tj$kr#|�%||��	ddd����t|
��	ddd��dS#1swxYwY��)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�kSSLStreamTyperW�
SSLSetIOFuncs�_read_callback_pointer�_write_callback_pointerr�_connection_ref_lock�idr)�SSLSetConnection�
isinstance�bytes�encode�SSLSetPeerDomainNamergrlrr�SSLSetProtocolVersionMin�SSLSetProtocolVersionMax�SSLSetSessionOption�"kSSLSessionOptionBreakOnServerAuthrrZr[rr\�SSLSetCertificaterd�SSLHandshaker:r,rC�errSSLServerAuthCompletedr�)r_�server_hostnamer�r��min_version�max_version�client_cert�
client_key�client_key_passphrase�alpn_protocolsrk�handles            r#�	handshakezWrappedSocket.handshake�s���$ �0��-�.�
�0L�
�
����'��L�0�2I�
�
��	�� � � �
"�	,�	,���X�X�
�*�F��,�,�,� �1�*�
�2���,�,�,�'+��V�$�		,�	,�	,�	,�	,�	,�	,�	,�	,�	,�	,����	,�	,�	,�	,��*�4�<��@�@���� � � ��	%��o�u�5�5�
B�"1�"8�"8��"A�"A���2���o�s�?�/C�/C���F�
�V�$�$�$�	
������	
� � ��0�0�0��2�4�<��M�M���� � � ��2�4�<��M�M���� � � ��	%��1��1���m�N�PT���F�
�V�$�$�$��	%�1D�1F�1F�.�D�N�D�.�&=����Z�'�'�D�#��/���d�>U�V�V�F��V�$�$�$�	��%�%�'�'�

�

�!�.�t�|�<�<���]�;�;�;� �.�)>�?�?�?��}�F�F�F��)�)�&�,�?�?�?��

�

�

�

�

�

�

�%�V�,�,�,��

�

�

�

�

�

�

�

�

�

�

�

����

�

�

�

�	s+�+7B.�.B2�5B2�3A%L�$L�L�Lc�4�|j���S�N)r,�fileno�r_s r#r�zWrappedSocket.fileno7s���{�!�!�#�#�#r"c�v�|jdkr|xjdzc_|jr|���dSdS)Nrr)rXrYrbr�s r#�_decref_socketioszWrappedSocket._decref_socketios;sI�����"�"����1�$����<�	��J�J�L�L�L�L�L�	�	r"c�n�tj|��}|�||��}|d|�}|Sr�)r2�create_string_bufferr5)r_�bufsizrF�
bytes_readrOs     r#�recvzWrappedSocket.recvAs8���,�V�4�4���^�^�F�F�3�3�
��k�z�k�"���r"Nc	�@�|jrdS|�t|��}tj|z�|��}tjd��}|���5tj|j	||tj
|����}ddd��n#1swxYwY|tjkr |j
dkrtjd���n>|tjtjfvr|���nt'|��|j
S)Nrzrecv timed out)rYrgr2r3�from_buffer�c_size_trdr	�SSLReadrWr�r
r:r�r,rCr6�errSSLClosedNoNotifyrbr)r_rF�nbytes�processed_bytesrks     r#r5zWrappedSocket.recv_intoGsX���<�	��1��>���[�[�F��-�&�(�5�5�f�=�=�� �/�!�,�,��
�
!�
!�
#�
#�	�	��%���f�f�f�l�?�.K�.K���F�	�	�	�	�	�	�	�	�	�	�	����	�	�	�	��]�3�3�3�
�$��)�)��n�%5�6�6�6�*���.��.�
�
�
�
�J�J�L�L�L�L��V�$�$�$��$�$s�%/B � B$�'B$c��||_dSr��r])r_rCs  r#r^zWrappedSocket.settimeoutrs
����
�
�
r"c��|jSr�r�r�s r#r-zWrappedSocket.gettimeoutus
���}�r"c	��tjd��}|���5tj|j|t
|��tj|����}ddd��n#1swxYwY|tj	kr|j
dkrtjd���t|��|j
S)Nrzsend timed out)r2r�rdr	�SSLWriterWrgr�r
r:r�r,rCr)r_rOr�rks    r#rMzWrappedSocket.sendxs��� �/�!�,�,��
�
!�
!�
#�
#�	�	��&���d�C��I�I�v�|�O�/L�/L���F�	�	�	�	�	�	�	�	�	�	�	����	�	�	�	�
�]�3�3�3��8M�QR�8R�8R��.�!1�2�2�2��V�$�$�$��$�$s�<A1�1A5�8A5c��d}|t|��kr?|�|||tz���}||z
}|t|��k�=dSdS�Nr)rgrM�SSL_WRITE_BLOCKSIZE)r_rO�
total_sentrPs    r#ryzWrappedSocket.sendall�sb���
��3�t�9�9�$�$��9�9�T�*�z�<O�/O�"O�P�Q�Q�D��$��J��3�t�9�9�$�$�$�$�$�$r"c��|���5tj|j��ddd��dS#1swxYwYdSr�)rdr	�SSLCloserWr�s r#�shutdownzWrappedSocket.shutdown�s���
�
!�
!�
#�
#�	,�	,���d�l�+�+�+�	,�	,�	,�	,�	,�	,�	,�	,�	,�	,�	,�	,����	,�	,�	,�	,�	,�	,s�<�A�Ac���|jdkr�d|_|jr tj|j��d|_|jr tj|j��d|_|jrYtj|j��tj|j��tj
|j��dx|_|_|j�
��S|xjdzc_dS)NrT)rXrYrWrror\rZr	�SecKeychainDelete�shutil�rmtreer[r,rbr�s r#rbzWrappedSocket.close�s������"�"��D�L��|�
$��(���6�6�6�#����&�
/��(��)@�A�A�A�*.��'��~�
;��*�4�>�:�:�:��(���8�8�8��
�d�0�1�1�1�6:�:����!3��;�$�$�&�&�&����1�$����r"Fc�\�|std���tj��}d}d}	tj|jtj|����}t|��|s1	|rtj	|��|rtj	|��dSdStj
|��}|s1	|rtj	|��|rtj	|��dSdStj|d��}|sJ�tj|��}|sJ�tj
|��}tj|��}	tj|	|��}|rtj	|��|rtj	|��n2#|rtj	|��|rtj	|��wwxYw|S)Nz2SecureTransport only supports dumping binary certsr)�
ValueErrorr	r�r�rWr2r�rrro�SecTrustGetCertificateCount�SecTrustGetCertificateAtIndex�SecCertificateCopyData�CFDataGetLength�CFDataGetBytePtrrK)
r_�binary_formr��certdata�	der_bytesrk�
cert_count�leaf�data_lengthr>s
          r#�getpeercertzWrappedSocket.getpeercert�s���(�	S��Q�R�R�R��$�&�&�����	�	0��.�t�|�V�\�%�=P�=P�Q�Q�F��V�$�$�$��
��&�
3��(��2�2�2��
0��(��/�/�/�/�/�
0�
0�'"�=�e�D�D�J��
���
3��(��2�2�2��
0��(��/�/�/�/�/�
0�
0��9�%��C�C�D��K�K�K� �6�t�<�<�H��O�O�O�(�8��B�B�K�(�9�(�C�C�K��(��k�B�B�I��
3��(��2�2�2��
0��(��/�/�/����
3��(��2�2�2��
0��(��/�/�/�/�
0�����s�=E:�E:�A.E:�:/F)c��tj��}tj|jt	j|����}t
|��|jtj	krtjd���|jtjkrdS|jtj
krdS|jtjkrdS|jtjkrdS|jtjkrdStjd|z���)Nz(SecureTransport does not support TLS 1.3zTLSv1.2zTLSv1.1�TLSv1�SSLv3�SSLv2zUnknown TLS version: %r)r	�SSLProtocol�SSLGetNegotiatedProtocolVersionrWr2r�rr�r
�kTLSProtocol13rr��kTLSProtocol12�kTLSProtocol11�
kTLSProtocol1�
kSSLProtocol3�
kSSLProtocol2)r_�protocolrks   r#rxzWrappedSocket.version�s����'�)�)���9��L�&�,�x�0�0�
�
��	�� � � ��>�]�9�9�9��,�I�J�J�J�
�^�}�;�
;�
;��9�
�^�}�;�
;�
;��9�
�^�}�:�
:�
:��7�
�^�}�:�
:�
:��7�
�^�}�:�
:�
:��7��,�8�8�C�D�D�Dr"c�&�|xjdz
c_dS�Nr)rXr�s r#�_reusezWrappedSocket._reuse�s�����q� ����r"c�h�|jdkr|���dS|xjdzc_dSr�)rXrbr�s r#�_dropzWrappedSocket._drop�s;�����"�"��J�J�L�L�L�L�L����1�$����r"r�)F)�__name__�
__module__�__qualname__�__doc__r`�
contextlib�contextmanagerrdrlrrr�rwr�r�r�r�r5r^r-rMryr�rbr�rxr�r�r!r"r#rTrTFs���������"�"�"�$�������(!�!�!�4�4�4�!E�!E�!E�F&"�&"�&"�P[�[�[�z$�$�$�������)%�)%�)%�)%�V � � ����%�%�%�"���,�,�,�%�%�%�&8�8�8�8�tE�E�E�*!�!�!�%�%�%�%�%r"rT���c�H�|xjdz
c_t|||d���S)NrT)rb)rXr)r_�mode�bufsizes   r#�makefilers-�����q� ����4��w�d�;�;�;�;r"�rc�*�d}t|||g|�Ri|��Sr�r)r_r�	buffering�args�kwargss     r#rrs+���	� ��t�Y�H��H�H�H��H�H�Hr"c���eZdZdZd�Zed���Zejd���Zed���Zejd���Zed���Z	e	jd���Z	d	�Z
d
�Zd�Zdd
�Z
dd�Zd�Z				dd�ZdS)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|_	dSrV)
�_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#r`zSecureTransportContext.__init__sS��/C�H�/M�,���4�,���
����!��� ������&*��#�#����r"c��dS)��
        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	���tr"c��dS)rNr!�r_r�s  r#rz%SecureTransportContext.check_hostname*s	��	
�r"c��|jSr��rr�s r#�optionszSecureTransportContext.options2s���}�r"c��||_dSr�rrs  r#rzSecureTransportContext.options<s����
�
�
r"c�@�|jrtjntjSr�)rr�
CERT_REQUIRED�	CERT_NONEr�s r#�verify_modez"SecureTransportContext.verify_modeAs��$(�L�C�s� � �c�m�Cr"c�8�|tjkrdnd|_dS)NTF)rr!rrs  r#r#z"SecureTransportContext.verify_modeEs��$��(9�9�9�t�t�u����r"c��dSr�r!r�s r#�set_default_verify_pathsz/SecureTransportContext.set_default_verify_pathsIs	��	
�r"c�*�|���Sr�)r&r�s r#�load_default_certsz)SecureTransportContext.load_default_certsUs���,�,�.�.�.r"c�N�|tjjkrtd���dS)Nz5SecureTransport doesn't support custom cipher strings)rr�DEFAULT_CIPHERSr�)r_rjs  r#�set_ciphersz"SecureTransportContext.set_ciphersXs)���d�i�/�/�/��T�U�U�U�0�/r"Nc��|�td���|�(t|��5	ddd��n#1swxYwY|p||_dS)Nz1SecureTransport does not support cert directories)r�r�r)r_�cafile�capath�cadatas    r#�load_verify_locationsz,SecureTransportContext.load_verify_locations]s������P�Q�Q�Q����f���
�
��
�
�
�
�
�
�
�
�
�
�
����
�
�
�
�$�-�v����s�1�5�5c�0�||_||_||_dSr�)rr�_client_cert_passphrase)r_�certfile�keyfile�passwords    r#�load_cert_chainz&SecureTransportContext.load_cert_chainis ��$���"���'/��$�$�$r"c�p�ttd��std���d�|D��|_dS)z�
        Sets the ALPN protocols that will later be set on the context.

        Raises a NotImplementedError if ALPN is not supported.
        rnz2SecureTransport supports ALPN only in macOS 10.12+c�6�g|]}tj|����Sr!)�six�
ensure_binary)�.0�ps  r#�
<listcomp>z=SecureTransportContext.set_alpn_protocols.<locals>.<listcomp>xs#��H�H�H��� 1�!� 4� 4�H�H�Hr"N)�hasattrr	�NotImplementedErrorr)r_rps  r#�set_alpn_protocolsz)SecureTransportContext.set_alpn_protocolsnsK���x�!6�7�7�	�%�D���
� I�H�i�H�H�H����r"FTc���|rJ�|sJ�|sJ�t|��}|�||j|j|j|j|j|j|j|j	�	�	|Sr�)
rTr�rrrrrrrr)r_�sock�server_side�do_handshake_on_connect�suppress_ragged_eofsr�r@s       r#�wrap_socketz"SecureTransportContext.wrap_socketzs�������&�&�&�&�#�#�#�#�'�t�,�,��	� � ���L������������'�� �
	
�
	
�
	
��r")NNN)NN)FTTN)r�r�r�r�r`�propertyr�setterrr#r&r(r+r0r6r@rFr!r"r#rrsk��������$�$�$�����X����
�
���
�����X��
�^����^���D�D��X�D���E�E���E�

�

�

�/�/�/�V�V�V�

.�
.�
.�
.�0�0�0�0�

I�
I�
I�� $�!��
�����r"r)r)rN)er��
__future__rr�r2r0�os.pathr�r�r,rrz�	threading�weakrefr9�r�	util.ssl_r�_securetransport.bindingsrr	r
�_securetransport.low_levelrrr
rrrr�ImportError�packages.backports.makefiler�__all__rr&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_SHArh�PROTOCOL_TLSr�r�r
r>r�rr�rrr�rrrrrIrR�SSLReadFuncr��SSLWriteFuncr��objectrTrrr!r"r#�<module>rxs���4�4�j'�&�&�&�&�&�����
�
�
�
���������
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
���������
�
�
�
�������+�+�+�+�+�+�N�N�N�N�N�N�N�N�N�N�����������������@�"�"�"�"�"�"�"���@�@�@��K�?�?�?�?�?�?�?�?�@����!�"8�
9�����L���y�+��$/�7�.�0�0��%�y�~�'�'�����9��9��7��7��?��=��5��5��9��6��9��6��7��4��7��4��5��2��5��2��(��(��1��1��*��(��1��1��.��.�=�
�J	��
�3�]�5Q�R��-�5�}�7S�T���
�7�3� �!�!���#��#�0���+�,��7�3� �!�!���#��#�0���+�,��7�3� �!�!���#��#�0���+�,��7�3�"�#�#���$��$�2���-�.��7�3�"�#�#���$��$�2���-�.�	(�	(�	(�	)�	)�	)�4,�4,�4,�n0,�0,�0,�l.��-�n�=�=��/�(�/��@�@��v%�v%�v%�v%�v%�F�v%�v%�v%�r
�I�<�<�<�<�<�I�I�I�I�"�
��H�H�H�H�H�V�H�H�H�H�Hs�A#�#
A3�2A3