U
    ςdm                     @  s   d dl mZ d dlZd dlmZmZ d dlmZ d dl	m
Z
 G dd dejdZeed	rheejj G d
d dejdZeed	reejj dS )    )annotationsN)UnsupportedAlgorithm_Reasons)openssl)_serializationc                   @  sb   e Zd Zedd dddZejdddddd	Zejdd
ddZejdddddZ	dS )X25519PublicKeybytesdatareturnc                 C  s*   ddl m} | s tdtj||S Nr   )backendz3X25519 is not supported by this version of OpenSSL.),cryptography.hazmat.backends.openssl.backendr   x25519_supportedr   r   UNSUPPORTED_EXCHANGE_ALGORITHMZx25519_load_public_bytesclsr
   r    r   m/var/www/html/myproject/myenv/lib/python3.8/site-packages/cryptography/hazmat/primitives/asymmetric/x25519.pyfrom_public_bytes   s    z!X25519PublicKey.from_public_bytes_serialization.Encodingz_serialization.PublicFormat)encodingformatr   c                 C  s   dS )z9
        The serialized bytes of the public key.
        Nr   )selfr   r   r   r   r   public_bytes   s    zX25519PublicKey.public_bytesr   c                 C  s   dS )z`
        The raw bytes of the public key.
        Equivalent to public_bytes(Raw, Raw).
        Nr   r   r   r   r   public_bytes_raw%   s    z X25519PublicKey.public_bytes_rawobjectbool)otherr   c                 C  s   dS )z"
        Checks equality.
        Nr   )r   r    r   r   r   __eq__,   s    zX25519PublicKey.__eq__N)
__name__
__module____qualname__classmethodr   abcabstractmethodr   r   r!   r   r   r   r   r      s   	r   )	metaclassx25519c                   @  s   e Zd Zed dddZedd dddZejddd	d
ZejdddddddZ	ejddddZ
ejdddddZdS )X25519PrivateKeyr   c                 C  s(   ddl m} | s tdtj| S r   )r   r   r   r   r   r   Zx25519_generate_key)r   r   r   r   r   generate9   s    zX25519PrivateKey.generater   r	   c                 C  s*   ddl m} | s tdtj||S r   )r   r   r   r   r   r   Zx25519_load_private_bytesr   r   r   r   from_private_bytesD   s    z#X25519PrivateKey.from_private_bytesr   c                 C  s   dS )zJ
        Returns the public key assosciated with this private key
        Nr   r   r   r   r   
public_keyP   s    zX25519PrivateKey.public_keyr   z_serialization.PrivateFormatz)_serialization.KeySerializationEncryption)r   r   encryption_algorithmr   c                 C  s   dS )z:
        The serialized bytes of the private key.
        Nr   )r   r   r   r.   r   r   r   private_bytesV   s    zX25519PrivateKey.private_bytesc                 C  s   dS )zr
        The raw bytes of the private key.
        Equivalent to private_bytes(Raw, Raw, NoEncryption()).
        Nr   r   r   r   r   private_bytes_rawa   s    z"X25519PrivateKey.private_bytes_raw)peer_public_keyr   c                 C  s   dS )zY
        Performs a key exchange operation using the provided peer's public key.
        Nr   )r   r1   r   r   r   exchangeh   s    zX25519PrivateKey.exchangeN)r"   r#   r$   r%   r+   r,   r&   r'   r-   r/   r0   r2   r   r   r   r   r*   8   s   

r*   )
__future__r   r&   Zcryptography.exceptionsr   r   Z"cryptography.hazmat.bindings._rustr   Zrust_opensslZcryptography.hazmat.primitivesr   ABCMetar   hasattrregisterr)   r*   r   r   r   r   <module>   s   &
8
