o
    e                     @  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	r4eejj G d
d dejdZeedrLeejj dS dS )    )annotationsN)UnsupportedAlgorithm_Reasons)openssl)_serializationc                   @  sZ   e Zd ZedddZejdd
dZejdddZejdddZ	ejdddZ
dS )Ed25519PublicKeydatabytesreturnc                 C  *   ddl m} | stdtj||S Nr   )backendz4ed25519 is not supported by this version of OpenSSL.),cryptography.hazmat.backends.openssl.backendr   ed25519_supportedr   r    UNSUPPORTED_PUBLIC_KEY_ALGORITHMed25519_load_public_bytesclsr   r    r   d/var/www/html/venv/lib/python3.10/site-packages/cryptography/hazmat/primitives/asymmetric/ed25519.pyfrom_public_bytes      
z"Ed25519PublicKey.from_public_bytesencoding_serialization.Encodingformat_serialization.PublicFormatc                 C     dS )z9
        The serialized bytes of the public key.
        Nr   )selfr   r   r   r   r   public_bytes       zEd25519PublicKey.public_bytesc                 C  r   )z`
        The raw bytes of the public key.
        Equivalent to public_bytes(Raw, Raw).
        Nr   r   r   r   r   public_bytes_raw%   r   z!Ed25519PublicKey.public_bytes_raw	signatureNonec                 C  r   )z'
        Verify the signature.
        Nr   )r   r"   r   r   r   r   verify,   r   zEd25519PublicKey.verifyotherobjectboolc                 C  r   )z"
        Checks equality.
        Nr   )r   r%   r   r   r   __eq__2   r   zEd25519PublicKey.__eq__N)r   r	   r
   r   )r   r   r   r   r
   r	   r
   r	   )r"   r	   r   r	   r
   r#   )r%   r&   r
   r'   )__name__
__module____qualname__classmethodr   abcabstractmethodr   r!   r$   r(   r   r   r   r   r      s    	r   )	metaclassed25519c                   @  sh   e Zd ZedddZedddZejdd	d
ZejdddZ	ejdddZ
ejdddZdS )Ed25519PrivateKeyr
   c                 C  s(   ddl m} | stdtj| S r   )r   r   r   r   r   r   ed25519_generate_key)r   r   r   r   r   generate>   s   zEd25519PrivateKey.generater   r	   c                 C  r   r   )r   r   r   r   r   r   ed25519_load_private_bytesr   r   r   r   from_private_bytesJ   r   z$Ed25519PrivateKey.from_private_bytesr   c                 C  r   )zD
        The Ed25519PublicKey derived from the private key.
        Nr   r    r   r   r   
public_keyV   r   zEd25519PrivateKey.public_keyr   r   r   _serialization.PrivateFormatencryption_algorithm)_serialization.KeySerializationEncryptionc                 C  r   )z:
        The serialized bytes of the private key.
        Nr   )r   r   r   r9   r   r   r   private_bytes\   r   zEd25519PrivateKey.private_bytesc                 C  r   )zr
        The raw bytes of the private key.
        Equivalent to private_bytes(Raw, Raw, NoEncryption()).
        Nr   r    r   r   r   private_bytes_rawg   r   z#Ed25519PrivateKey.private_bytes_rawc                 C  r   )z!
        Signs the data.
        Nr   )r   r   r   r   r   signn   r   zEd25519PrivateKey.signN)r
   r2   )r   r	   r
   r2   )r
   r   )r   r   r   r8   r9   r:   r
   r	   r)   )r   r	   r
   r	   )r*   r+   r,   r-   r4   r6   r.   r/   r7   r;   r<   r=   r   r   r   r   r2   =   s    
r2   x25519)
__future__r   r.   cryptography.exceptionsr   r   "cryptography.hazmat.bindings._rustr   rust_opensslcryptography.hazmat.primitivesr   ABCMetar   hasattrregisterr1   r2   r   r   r   r   <module>   s   
+
8