o
    )%a(                     @   s  d dl Z G dd de jdZG dd de jdZG dd de jdZG d	d
 d
e jdZG dd de jdZG dd de jdZG dd de jdZG dd de jdZ	G dd de jdZ
G dd de jdZG dd de jdZG dd de jdZG dd de jdZdS )    Nc                   @   6   e Zd Zejdd Zejdd Zejdd ZdS )CipherBackendc                 C      dS )zI
        Return True if the given cipher and mode are supported.
        N selfZciphermoder   r   I/usr/lib/python3/dist-packages/cryptography/hazmat/backends/interfaces.pycipher_supported
       zCipherBackend.cipher_supportedc                 C   r   )zF
        Get a CipherContext that can be used for encryption.
        Nr   r   r   r   r	   create_symmetric_encryption_ctx   r   z-CipherBackend.create_symmetric_encryption_ctxc                 C   r   )zF
        Get a CipherContext that can be used for decryption.
        Nr   r   r   r   r	   create_symmetric_decryption_ctx   r   z-CipherBackend.create_symmetric_decryption_ctxN)__name__
__module____qualname__abcabstractmethodr
   r   r   r   r   r   r	   r   	   s    

r   )	metaclassc                   @   (   e Zd Zejdd Zejdd ZdS )HashBackendc                 C   r   )zQ
        Return True if the hash algorithm is supported by this backend.
        Nr   r   	algorithmr   r   r	   hash_supported   r   zHashBackend.hash_supportedc                 C   r   )zH
        Create a HashContext for calculating a message digest.
        Nr   r   r   r   r	   create_hash_ctx$   r   zHashBackend.create_hash_ctxN)r   r   r   r   r   r   r   r   r   r   r	   r      
    
r   c                   @   r   )HMACBackendc                 C   r   )zb
        Return True if the hash algorithm is supported for HMAC by this
        backend.
        Nr   r   r   r   r	   hmac_supported,   r   zHMACBackend.hmac_supportedc                 C   r   zQ
        Create a context for calculating a message authentication code.
        Nr   )r   keyr   r   r   r	   create_hmac_ctx3   r   zHMACBackend.create_hmac_ctxN)r   r   r   r   r   r   r   r   r   r   r	   r   +   
    
r   c                   @   r   )CMACBackendc                 C   r   )zX
        Returns True if the block cipher is supported for CMAC by this backend
        Nr   r   r   r   r	   cmac_algorithm_supported;   r   z$CMACBackend.cmac_algorithm_supportedc                 C   r   r   r   r   r   r   r	   create_cmac_ctxA   r   zCMACBackend.create_cmac_ctxN)r   r   r   r   r   r"   r#   r   r   r   r	   r!   :   r   r!   c                   @   r   )PBKDF2HMACBackendc                 C   r   )zd
        Return True if the hash algorithm is supported for PBKDF2 by this
        backend.
        Nr   r   r   r   r	   pbkdf2_hmac_supportedI   r   z'PBKDF2HMACBackend.pbkdf2_hmac_supportedc                 C   r   )zN
        Return length bytes derived from provided PBKDF2 parameters.
        Nr   )r   r   lengthsaltZ
iterationskey_materialr   r   r	   derive_pbkdf2_hmacP   r   z$PBKDF2HMACBackend.derive_pbkdf2_hmacN)r   r   r   r   r   r%   r)   r   r   r   r	   r$   H   r    r$   c                   @   sR   e Z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	dS )
RSABackendc                 C   r   )zq
        Generate an RSAPrivateKey instance with public_exponent and a modulus
        of key_size bits.
        Nr   r   Zpublic_exponentkey_sizer   r   r	   generate_rsa_private_keyZ   r   z#RSABackend.generate_rsa_private_keyc                 C   r   )zQ
        Returns True if the backend supports the given padding options.
        Nr   )r   Zpaddingr   r   r	   rsa_padding_supporteda   r   z RSABackend.rsa_padding_supportedc                 C   r   )zg
        Returns True if the backend supports the given parameters for key
        generation.
        Nr   r+   r   r   r	   !generate_rsa_parameters_supportedg   r   z,RSABackend.generate_rsa_parameters_supportedc                 C   r   )z4
        Returns an RSAPrivateKey provider.
        Nr   r   Znumbersr   r   r	   load_rsa_private_numbersn   r   z#RSABackend.load_rsa_private_numbersc                 C   r   )z3
        Returns an RSAPublicKey provider.
        Nr   r0   r   r   r	   load_rsa_public_numberst   r   z"RSABackend.load_rsa_public_numbersN)
r   r   r   r   r   r-   r.   r/   r1   r2   r   r   r   r	   r*   Y   s    



r*   c                   @   s|   e Z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	ejdd Z
ejdd Zejdd ZdS )
DSABackendc                 C   r   )zT
        Generate a DSAParameters instance with a modulus of key_size bits.
        Nr   r   r,   r   r   r	   generate_dsa_parameters|   r   z"DSABackend.generate_dsa_parametersc                 C   r   )zf
        Generate a DSAPrivateKey instance with parameters as a DSAParameters
        object.
        Nr   r   Z
parametersr   r   r	   generate_dsa_private_key   r   z#DSABackend.generate_dsa_private_keyc                 C   r   )zH
        Generate a DSAPrivateKey instance using key size only.
        Nr   r4   r   r   r	   'generate_dsa_private_key_and_parameters   r   z2DSABackend.generate_dsa_private_key_and_parametersc                 C   r   )zX
        Return True if the hash algorithm is supported by the backend for DSA.
        Nr   r   r   r   r	   dsa_hash_supported   r   zDSABackend.dsa_hash_supportedc                 C   r   )zU
        Return True if the parameters are supported by the backend for DSA.
        Nr   )r   pqgr   r   r	   dsa_parameters_supported   r   z#DSABackend.dsa_parameters_supportedc                 C   r   )z3
        Returns a DSAPrivateKey provider.
        Nr   r0   r   r   r	   load_dsa_private_numbers   r   z#DSABackend.load_dsa_private_numbersc                 C   r   )z2
        Returns a DSAPublicKey provider.
        Nr   r0   r   r   r	   load_dsa_public_numbers   r   z"DSABackend.load_dsa_public_numbersc                 C   r   )z3
        Returns a DSAParameters provider.
        Nr   r0   r   r   r	   load_dsa_parameter_numbers   r   z%DSABackend.load_dsa_parameter_numbersN)r   r   r   r   r   r5   r7   r8   r9   r=   r>   r?   r@   r   r   r   r	   r3   {   s"    






r3   c                   @   sn   e Z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	ejdd Z
ejdd ZdS )EllipticCurveBackendc                 C   r   )z
        Returns True if the backend supports the named elliptic curve with the
        specified signature algorithm.
        Nr   )r   Zsignature_algorithmcurver   r   r	   ,elliptic_curve_signature_algorithm_supported   r   zAEllipticCurveBackend.elliptic_curve_signature_algorithm_supportedc                 C   r   )zP
        Returns True if the backend supports the named elliptic curve.
        Nr   r   rB   r   r   r	   elliptic_curve_supported   r   z-EllipticCurveBackend.elliptic_curve_supportedc                 C   r   )zW
        Return an object conforming to the EllipticCurvePrivateKey interface.
        Nr   rD   r   r   r	   #generate_elliptic_curve_private_key   r   z8EllipticCurveBackend.generate_elliptic_curve_private_keyc                 C   r   )zT
        Return an EllipticCurvePublicKey provider using the given numbers.
        Nr   r0   r   r   r	   "load_elliptic_curve_public_numbers   r   z7EllipticCurveBackend.load_elliptic_curve_public_numbersc                 C   r   )zU
        Return an EllipticCurvePrivateKey provider using the given numbers.
        Nr   r0   r   r   r	   #load_elliptic_curve_private_numbers   r   z8EllipticCurveBackend.load_elliptic_curve_private_numbersc                 C   r   )zV
        Returns whether the exchange algorithm is supported by this backend.
        Nr   )r   r   rB   r   r   r	   +elliptic_curve_exchange_algorithm_supported   r   z@EllipticCurveBackend.elliptic_curve_exchange_algorithm_supportedc                 C   r   )zL
        Compute the private key given the private value and curve.
        Nr   )r   Zprivate_valuerB   r   r   r	   !derive_elliptic_curve_private_key   r   z6EllipticCurveBackend.derive_elliptic_curve_private_keyN)r   r   r   r   r   rC   rE   rF   rG   rH   rI   rJ   r   r   r   r	   rA      s    





rA   c                   @   r   )PEMSerializationBackendc                 C   r   )zz
        Loads a private key from PEM encoded data, using the provided password
        if the data is encrypted.
        Nr   r   dataZpasswordr   r   r	   load_pem_private_key   r   z,PEMSerializationBackend.load_pem_private_keyc                 C   r   )z;
        Loads a public key from PEM encoded data.
        Nr   r   rM   r   r   r	   load_pem_public_key   r   z+PEMSerializationBackend.load_pem_public_keyc                 C   r   )zC
        Load encryption parameters from PEM encoded data.
        Nr   rO   r   r   r	   load_pem_parameters   r   z+PEMSerializationBackend.load_pem_parametersN)r   r   r   r   r   rN   rP   rQ   r   r   r   r	   rK          

rK   c                   @   r   )DERSerializationBackendc                 C   r   )zy
        Loads a private key from DER encoded data. Uses the provided password
        if the data is encrypted.
        Nr   rL   r   r   r	   load_der_private_key   r   z,DERSerializationBackend.load_der_private_keyc                 C   r   )z;
        Loads a public key from DER encoded data.
        Nr   rO   r   r   r	   load_der_public_key   r   z+DERSerializationBackend.load_der_public_keyc                 C   r   )zC
        Load encryption parameters from DER encoded data.
        Nr   rO   r   r   r	   load_der_parameters   r   z+DERSerializationBackend.load_der_parametersN)r   r   r   r   r   rT   rU   rV   r   r   r   r	   rS      rR   rS   c                   @   s   e Z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	ejdd Z
ejdd Zejdd Zejdd ZdS )X509Backendc                 C   r   )zB
        Load an X.509 certificate from PEM encoded data.
        Nr   rO   r   r   r	   load_pem_x509_certificate  r   z%X509Backend.load_pem_x509_certificatec                 C   r   )zB
        Load an X.509 certificate from DER encoded data.
        Nr   rO   r   r   r	   load_der_x509_certificate  r   z%X509Backend.load_der_x509_certificatec                 C   r   )z:
        Load an X.509 CSR from DER encoded data.
        Nr   rO   r   r   r	   load_der_x509_csr  r   zX509Backend.load_der_x509_csrc                 C   r   )z:
        Load an X.509 CSR from PEM encoded data.
        Nr   rO   r   r   r	   load_pem_x509_csr  r   zX509Backend.load_pem_x509_csrc                 C   r   )zI
        Create and sign an X.509 CSR from a CSR builder object.
        Nr   r   builderZprivate_keyr   r   r   r	   create_x509_csr   r   zX509Backend.create_x509_csrc                 C   r   )zX
        Create and sign an X.509 certificate from a CertificateBuilder object.
        Nr   r\   r   r   r	   create_x509_certificate&  r   z#X509Backend.create_x509_certificatec                 C   r   )z|
        Create and sign an X.509 CertificateRevocationList from a
        CertificateRevocationListBuilder object.
        Nr   r\   r   r   r	   create_x509_crl,  r   zX509Backend.create_x509_crlc                 C   r   )ze
        Create a RevokedCertificate object from a RevokedCertificateBuilder
        object.
        Nr   )r   r]   r   r   r	   create_x509_revoked_certificate3  r   z+X509Backend.create_x509_revoked_certificatec                 C   r   )zG
        Compute the DER encoded bytes of an X509 Name object.
        Nr   )r   namer   r   r	   x509_name_bytes:  r   zX509Backend.x509_name_bytesN)r   r   r   r   r   rX   rY   rZ   r[   r^   r_   r`   ra   rc   r   r   r   r	   rW     s&    







rW   c                   @   s~   e Z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	ejdd Z
ejdddZejdd ZdS )	DHBackendc                 C   r   )z
        Generate a DHParameters instance with a modulus of key_size bits.
        Using the given generator. Often 2 or 5.
        Nr   r   	generatorr,   r   r   r	   generate_dh_parametersB  r   z DHBackend.generate_dh_parametersc                 C   r   )zd
        Generate a DHPrivateKey instance with parameters as a DHParameters
        object.
        Nr   r6   r   r   r	   generate_dh_private_keyI  r   z!DHBackend.generate_dh_private_keyc                 C   r   )zx
        Generate a DHPrivateKey instance using key size only.
        Using the given generator. Often 2 or 5.
        Nr   re   r   r   r	   &generate_dh_private_key_and_parametersP  r   z0DHBackend.generate_dh_private_key_and_parametersc                 C   r   )z;
        Load a DHPrivateKey from DHPrivateNumbers
        Nr   r0   r   r   r	   load_dh_private_numbersW  r   z!DHBackend.load_dh_private_numbersc                 C   r   )z:
        Load a DHPublicKey from DHPublicNumbers.
        Nr   r0   r   r   r	   load_dh_public_numbers]  r   z DHBackend.load_dh_public_numbersc                 C   r   )z<
        Load DHParameters from DHParameterNumbers.
        Nr   r0   r   r   r	   load_dh_parameter_numbersc  r   z#DHBackend.load_dh_parameter_numbersNc                 C   r   )zV
        Returns whether the backend supports DH with these parameter values.
        Nr   )r   r:   r<   r;   r   r   r	   dh_parameters_supportedi  r   z!DHBackend.dh_parameters_supportedc                 C   r   )zw
        Returns True if the backend supports the serialization of DH objects
        with subgroup order (q).
        Nr   )r   r   r   r	   dh_x942_serialization_supportedo  r   z)DHBackend.dh_x942_serialization_supported)N)r   r   r   r   r   rg   rh   ri   rj   rk   rl   rm   rn   r   r   r   r	   rd   A  s"    





rd   c                   @   s   e Zd Zejdd ZdS )ScryptBackendc                 C   r   )zG
        Return bytes derived from provided Scrypt parameters.
        Nr   )r   r(   r'   r&   nrr:   r   r   r	   derive_scryptx  r   zScryptBackend.derive_scryptN)r   r   r   r   r   rr   r   r   r   r	   ro   w  s    ro   )r   ABCMetar   r   r   r!   r$   r*   r3   rA   rK   rS   rW   rd   ro   r   r   r   r	   <module>   s   "3/:6