U
    ʹ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
 d dlmZ G dd dejd	Zeed
rteejj G dd dejd	Zeed
reejj dS )    )annotationsN)UnsupportedAlgorithm_Reasons)openssl)_serialization)Bufferc                   @  sv   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	ejd d
ddZ
dS )X448PublicKeybytesdatareturnc                 C  s,   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   r/var/www/html/timesheet/backend/venv/lib/python3.8/site-packages/cryptography/hazmat/primitives/asymmetric/x448.pyr      s    zX448PublicKey.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X448PublicKey.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X448PublicKey.public_bytes_rawobjectbool)otherr   c                 C  s   dS )z"
        Checks equality.
        Nr   )r   r#   r   r   r   __eq__-   s    zX448PublicKey.__eq__c                 C  s   dS z!
        Returns a copy.
        Nr   r   r   r   r   __copy__3   s    zX448PublicKey.__copy__N)__name__
__module____qualname__classmethodr   abcabstractmethodr   r    r$   r&   r   r   r   r   r      s   	r   )	metaclassr   c                   @  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ejd 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   generate?   s    zX448PrivateKey.generater   r
   c                 C  s,   ddl m} | s tdtjtj|S r   )	r   r   r   r   r   r   r   r   from_private_bytesr   r   r   r   r1   K   s    z!X448PrivateKey.from_private_bytesr   c                 C  s   dS )zI
        Returns the public key associated with this private key
        Nr   r   r   r   r   
public_keyW   s    zX448PrivateKey.public_keyr   z_serialization.PrivateFormatz)_serialization.KeySerializationEncryptionr	   )r   r   encryption_algorithmr   c                 C  s   dS )z:
        The serialized bytes of the private key.
        Nr   )r   r   r   r3   r   r   r   private_bytes]   s    zX448PrivateKey.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_rawh   s    z X448PrivateKey.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   r6   r   r   r   exchangeo   s    zX448PrivateKey.exchangec                 C  s   dS r%   r   r   r   r   r   r&   u   s    zX448PrivateKey.__copy__N)r'   r(   r)   r*   r0   r1   r+   r,   r2   r4   r5   r7   r&   r   r   r   r   r.   >   s   
r.   )
__future__r   r+   cryptography.exceptionsr   r   "cryptography.hazmat.bindings._rustr   r   cryptography.hazmat.primitivesr   cryptography.utilsr   ABCMetar   hasattrregisterr   r.   r   r   r   r   <module>   s   +
>
