관리-도구
편집 파일: low_level.cpython-37.pyc
B ��`T6 � @ s� d Z ddlZddlZddlZddlZddlZddlZddlZddlZddl m Z mZmZ e� dej�Zdd� Zdd � Zd d� Zdd � Zdd� Zd&dd�Zdd� Zdd� Zdd� Zdd� Zdd� Zdd� Zddd d!d"d#�Zd$d%� ZdS )'a� Low-level helpers for the SecureTransport bindings. These are Python functions that are not directly related to the high-level APIs but are necessary to get them to work. They include a whole bunch of low-level CoreFoundation messing about and memory management. The concerns in this module are almost entirely about trying to avoid memory leaks and providing appropriate and useful assistance to the higher-level code. � N� )�CFConst�CoreFoundation�Securitys; -----BEGIN CERTIFICATE----- (.*?) -----END CERTIFICATE-----c C s t �t j| t| ��S )zv Given a bytestring, create a CFData object from it. This CFData object must be CFReleased by the caller. )r �CFDataCreate�kCFAllocatorDefault�len)Z bytestring� r �[/opt/alt/python37/lib/python3.7/site-packages/urllib3/contrib/_securetransport/low_level.py�_cf_data_from_bytes s r c C sZ t | �}dd� | D �}dd� | D �}tj| |� }tj| |� }t�tj|||tjtj�S )zK Given a list of Python tuples, create an associated CFDictionary. c s s | ]}|d V qdS )r Nr )�.0�tr r r � <genexpr>, s z-_cf_dictionary_from_tuples.<locals>.<genexpr>c s s | ]}|d V qdS )r Nr )r r r r r r - s )r r � CFTypeRefZCFDictionaryCreater ZkCFTypeDictionaryKeyCallBacksZkCFTypeDictionaryValueCallBacks)ZtuplesZdictionary_size�keys�valuesZcf_keysZ cf_valuesr r r �_cf_dictionary_from_tuples% s r c C s t �| �}t�tj|tj�}|S )zi Given a Python binary data, create a CFString. The string must be CFReleased by the caller. )�ctypes�c_char_pr ZCFStringCreateWithCStringr r �kCFStringEncodingUTF8)Zpy_bstrZc_str�cf_strr r r �_cfstr; s r c C s� d}yht �t jdt�t j��}|s*td��x>| D ]6}t|�}|sHtd��zt �||� W dt � |� X q0W W n@ t k r� } z"|r�t � |� t�d|f ��W dd}~X Y nX |S )z� Given a list of Python binary data, create an associated CFMutableArray. The array must be CFReleased by the caller. Raises an ssl.SSLError on failure. Nr zUnable to allocate memory!zUnable to allocate array: %s) r �CFArrayCreateMutabler r �byref�kCFTypeArrayCallBacks�MemoryErrorr �CFArrayAppendValue� CFRelease� BaseException�ssl�SSLError)�lstZcf_arr�itemr �er r r �_create_cfstring_arrayI s( "r$ c C sn t �| t �t j��}t�|tj�}|dkrXt �d�}t� ||dtj�}|sRt d��|j}|dk rj|�d�}|S )z� Creates a Unicode string from a CFString object. Used entirely for error reporting. Yes, it annoys me quite a lot that this function is this complex. Ni z'Error copying C string from CFStringRefzutf-8) r �cast�POINTER�c_void_pr ZCFStringGetCStringPtrr r �create_string_bufferZCFStringGetCString�OSError�value�decode)r* Zvalue_as_void_p�string�buffer�resultr r r �_cf_string_to_unicodeh s r/ c C s\ | dkrdS t �| d�}t|�}t�|� |dks:|dkrBd| }|dkrPtj}||��dS )z[ Checks the return code and throws an exception if there is an error to report r N� zOSStatus %s)r ZSecCopyErrorMessageStringr/ r r r r )�errorZexception_classZcf_error_string�outputr r r �_assert_no_error� s r3 c C s� | � dd�} dd� t�| �D �}|s.t�d��t�tjdt� tj ��}|sTt�d��ydx^|D ]V}t|�}|svt�d��t� tj|�}t�|� |s�t�d��t�||� t�|� q\W W n tk r� t�|� Y nX |S ) z� Given a bundle of certs in PEM format, turns them into a CFArray of certs that can be used to validate a cert chain. s � c S s g | ]}t �|�d ���qS )r )�base64� b64decode�group)r �matchr r r � <listcomp>� s z(_cert_array_from_pem.<locals>.<listcomp>zNo root certificates specifiedr zUnable to allocate memory!zUnable to build cert object!)�replace� _PEM_CERTS_RE�finditerr r r r r r r r r r ZSecCertificateCreateWithDatar r � Exception)Z pem_bundleZ der_certsZ cert_arrayZ der_bytesZcertdataZcertr r r �_cert_array_from_pem� s2 r>