o
    Vh.                     @  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                   @  sJ   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	dS )X448PublicKeydatabytesreturnc                 C  ,   ddl m} | stdtjtj|S Nr   )backendz1X448 is not supported by this version of OpenSSL.)	,cryptography.hazmat.backends.openssl.backendr   x448_supportedr   r   UNSUPPORTED_EXCHANGE_ALGORITHMrust_opensslx448from_public_bytesclsr   r    r   /var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/cryptography/hazmat/primitives/asymmetric/x448.pyr         zX448PublicKey.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X448PublicKey.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X448PublicKey.public_bytes_rawotherobjectboolc                 C  r   )z"
        Checks equality.
        Nr   )r   r#   r   r   r   __eq__,   r    zX448PublicKey.__eq__N)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      s    	r   )	metaclassr   c                   @  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 )X448PrivateKeyr
   c                 C  s*   ddl m} | stdtjtj S r   )	r   r   r   r   r   r   r   r   generate_key)r   r   r   r   r   generate8   s   
zX448PrivateKey.generater   r	   c                 C  r   r   )	r   r   r   r   r   r   r   r   from_private_bytesr   r   r   r   r2   D   r   z!X448PrivateKey.from_private_bytesr   c                 C  r   )zI
        Returns the public key associated with this private key
        Nr   r!   r   r   r   
public_keyP   r    zX448PrivateKey.public_keyr   r   r   _serialization.PrivateFormatencryption_algorithm)_serialization.KeySerializationEncryptionc                 C  r   )z:
        The serialized bytes of the private key.
        Nr   )r   r   r   r5   r   r   r   private_bytesV   r    zX448PrivateKey.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_rawa   r    z X448PrivateKey.private_bytes_rawpeer_public_keyc                 C  r   )zY
        Performs a key exchange operation using the provided peer's public key.
        Nr   )r   r9   r   r   r   exchangeh   r    zX448PrivateKey.exchangeN)r
   r/   )r   r	   r
   r/   )r
   r   )r   r   r   r4   r5   r6   r
   r	   r'   )r9   r   r
   r	   )r(   r)   r*   r+   r1   r2   r,   r-   r3   r7   r8   r:   r   r   r   r   r/   7   s    
r/   )
__future__r   r,   cryptography.exceptionsr   r   "cryptography.hazmat.bindings._rustr   r   cryptography.hazmat.primitivesr   ABCMetar   hasattrregisterr   r/   r   r   r   r   <module>   s   
%
8