File: //var/opt/nydus/ops/cryptography/hazmat/backends/openssl/__pycache__/ed25519.cpython-39.pyc
a
�,�h � @ sn d dl Z d dlmZ d dlmZ d dlmZmZmZm Z e j
rJd dlmZ G dd� de�Z
G dd � d e�ZdS )
� N)�
exceptions)�
serialization)�Ed25519PrivateKey�Ed25519PublicKey�_ED25519_KEY_SIZE�_ED25519_SIG_SIZE)�Backendc @ sP e Zd Zdd�dd�Zejejed�dd�Zed�d d
�Z eedd�d
d�Z
dS )�_Ed25519PublicKeyr ��backendc C s || _ || _d S �N��_backend� _evp_pkey��selfr Zevp_pkey� r �_/opt/nydus/tmp/pip-target-wkfpz8uv/lib64/python/cryptography/hazmat/backends/openssl/ed25519.py�__init__ s z_Ed25519PublicKey.__init__)�encoding�format�returnc C sV |t jju s|t jju r@|t jjus0|t jjur8td��| �� S | j�||| | jd �S )Nz3When using Raw both encoding and format must be Raw) r �Encoding�Raw�PublicFormat�
ValueError�_raw_public_bytesr Z_public_key_bytesr )r r r r r r �public_bytes s
�
�
�
���z_Ed25519PublicKey.public_bytes�r c 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�newr �_lib�EVP_PKEY_get_raw_public_keyr �openssl_assert�buffer�r �buf�buflen�resr r r r 0 s �z#_Ed25519PublicKey._raw_public_bytesN)� signature�datar c 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$ �EVP_MD_CTX_newr&