
    ӝgh                    ^   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
 d dlmZ  G d dej                  	      Z eed
      r%ej!                  ej"                  j                          G d dej                  	      Z eed      r&ej!                  ej"                  j$                         yy)    )annotationsN)UnsupportedAlgorithm_Reasons)openssl)_serialization)Bufferc                      e Zd Zedd       Zej                  	 	 	 	 	 	 d	d       Zej                  d
d       Zej                  dd       Z	ej                  dd       Z
ej                  dd       Zy)Ed448PublicKeyc                    ddl m} |j                         st        dt        j
                        t        j                  j                  |      S Nr   )backendz2ed448 is not supported by this version of OpenSSL.)	,cryptography.hazmat.backends.openssl.backendr   ed448_supportedr   r    UNSUPPORTED_PUBLIC_KEY_ALGORITHMrust_openssled448from_public_bytesclsdatar   s      s/var/www/enzed_healthcare/enzed_env/lib/python3.12/site-packages/cryptography/hazmat/primitives/asymmetric/ed448.pyr   z Ed448PublicKey.from_public_bytes   sC    H&&(&D99 
 !!33D99    c                     y)z9
        The serialized bytes of the public key.
        N )selfencodingformats      r   public_byteszEd448PublicKey.public_bytes       r   c                     y)z`
        The raw bytes of the public key.
        Equivalent to public_bytes(Raw, Raw).
        Nr   r   s    r   public_bytes_rawzEd448PublicKey.public_bytes_raw&   r   r   c                     y)z'
        Verify the signature.
        Nr   )r   	signaturer   s      r   verifyzEd448PublicKey.verify-   r   r   c                     y)z"
        Checks equality.
        Nr   )r   others     r   __eq__zEd448PublicKey.__eq__3   r   r   c                     yz!
        Returns a copy.
        Nr   r!   s    r   __copy__zEd448PublicKey.__copy__9   r   r   N)r   bytesreturnr
   )r   _serialization.Encodingr   z_serialization.PublicFormatr-   r,   r-   r,   )r$   r   r   r   r-   None)r'   objectr-   boolr-   r
   )__name__
__module____qualname__classmethodr   abcabstractmethodr   r"   r%   r(   r+   r   r   r   r
   r
      s    	: 	: 	) , 
	  	  	 
 	 
 	 r   r
   )	metaclassr   c                      e Zd Zed	d       Zed
d       Zej                  dd       Zej                  dd       Z	ej                  	 	 	 	 	 	 	 	 dd       Z
ej                  dd       Zej                  d	d       Zy)Ed448PrivateKeyc                    ddl m} |j                         st        dt        j
                        t        j                  j                         S r   )	r   r   r   r   r   r   r   r   generate_key)r   r   s     r   generatezEd448PrivateKey.generateE   sA    H&&(&D99 
 !!..00r   c                    ddl m} |j                         st        dt        j
                        t        j                  j                  |      S r   )	r   r   r   r   r   r   r   r   from_private_bytesr   s      r   rA   z"Ed448PrivateKey.from_private_bytesQ   sC    H&&(&D99 
 !!44T::r   c                     y)zB
        The Ed448PublicKey derived from the private key.
        Nr   r!   s    r   
public_keyzEd448PrivateKey.public_key]   r   r   c                     y)z!
        Signs the data.
        Nr   )r   r   s     r   signzEd448PrivateKey.signc   r   r   c                     y)z:
        The serialized bytes of the private key.
        Nr   )r   r   r   encryption_algorithms       r   private_byteszEd448PrivateKey.private_bytesi   r   r   c                     y)zr
        The raw bytes of the private key.
        Equivalent to private_bytes(Raw, Raw, NoEncryption()).
        Nr   r!   s    r   private_bytes_rawz!Ed448PrivateKey.private_bytes_rawt   r   r   c                     yr*   r   r!   s    r   r+   zEd448PrivateKey.__copy__{   r   r   N)r-   r<   )r   r   r-   r<   r3   )r   r   r-   r,   )r   r.   r   z_serialization.PrivateFormatrG   z)_serialization.KeySerializationEncryptionr-   r,   r/   )r4   r5   r6   r7   r?   rA   r8   r9   rC   rE   rH   rJ   r+   r   r   r   r<   r<   D   s    	1 	1 	; 	; 	 
 	 
 	) - H	
 
  	  	 r   r<   x448)
__future__r   r8   cryptography.exceptionsr   r   "cryptography.hazmat.bindings._rustr   r   cryptography.hazmat.primitivesr   cryptography.utilsr   ABCMetar
   hasattrregisterr   r<   r   r   r   <module>rU      s   
 # 
 B F 9 %.s{{ .b <!L..==>; ;| < \//??@ !r   