File: //lib/python3/dist-packages/cryptography/hazmat/backends/openssl/__pycache__/ed448.cpython-38.pyc
U
�e�]� � @ s� d dl mZmZmZ d dlmZmZ d dlmZ d dl m
Z
mZ dZdZ
e�e�G dd� de��Ze�e
�G d d
� d
e��ZdS )� )�absolute_import�division�print_function)�
exceptions�utils)�
serialization)�Ed448PrivateKey�Ed448PublicKey�9 �r c @ s, e Zd Zdd� Zdd� Zdd� Zdd� Zd S )
�_Ed448PublicKeyc C s || _ || _d S �N��_backend� _evp_pkey��selfZbackendZevp_pkey� r �L/usr/lib/python3/dist-packages/cryptography/hazmat/backends/openssl/ed448.py�__init__ s z_Ed448PublicKey.__init__c C st |t jjks|t jjkr@|t jjk s0|t jjk r8td��| �� S |t jkr^|t jjk r^td��| j� ||| | j
d �S )Nz3When using Raw both encoding and format must be Rawz?format must be SubjectPublicKeyInfo when encoding is PEM or DER)r �Encoding�Raw�PublicFormat�
ValueError�_raw_public_bytes�_PEM_DERZSubjectPublicKeyInfor Z_public_key_bytesr )r �encoding�formatr r r �public_bytes s4
�
�
�
���
�� �z_Ed448PublicKey.public_bytesc C sp | j j�dt�}| j j�dt�}| j j�| j||�}| j �|dk� | j �|d tk� | j j�|t�d d � S �Nzunsigned char []�size_t *� r ) r �_ffi�new�_ED448_KEY_SIZE�_lib�EVP_PKEY_get_raw_public_keyr �openssl_assert�buffer�r �buf�buflen�resr r r r 3 s �z!_Ed448PublicKey._raw_public_bytesc C s� | j j�� }| j �|| j jjk� | j j�|| j jj�}| j j�|| j jj| j jj| j jj| j �}| j �|dk� | j j�
||t|�|t|��}|dkr�| j �� t
j�d S )Nr! )r r% �Cryptography_EVP_MD_CTX_newr'