o
    ŒMfü  ã                   @   sœ   d Z ddlmZ ddlmZ zddlmZ W n ey!   dZY nw edur+g d¢Zng d¢ZejZejZej	Z	ej
Z
edurEejZejZej
fdd	„ZdS )
a\  Cryptography helpers for verifying and signing messages.

The simplest way to verify signatures is using :func:`verify_signature`::

    cert = open('certs.pem').read()
    valid = crypt.verify_signature(message, signature, cert)

If you're going to verify many messages with the same certificate, you can use
:class:`RSAVerifier`::

    cert = open('certs.pem').read()
    verifier = crypt.RSAVerifier.from_string(cert)
    valid = verifier.verify(message, signature)

To sign messages use :class:`RSASigner` with a private key::

    private_key = open('private_key.pem').read()
    signer = crypt.RSASigner.from_string(private_key)
    signature = signer.sign(message)

The code above also works for :class:`ES256Signer` and :class:`ES256Verifier`.
Note that these two classes are only available if your `cryptography` dependency
version is at least 1.4.0.
é    )Úbase)Úrsa)Úes256N)ÚES256SignerÚES256VerifierÚ	RSASignerÚRSAVerifierÚSignerÚVerifier)r   r   r	   r
   c                 C   s>   t |ttfƒr
|g}|D ]}| |¡}| | |¡r dS qdS )a  Verify an RSA or ECDSA cryptographic signature.

    Checks that the provided ``signature`` was generated from ``bytes`` using
    the private key associated with the ``cert``.

    Args:
        message (Union[str, bytes]): The plaintext message.
        signature (Union[str, bytes]): The cryptographic signature to check.
        certs (Union[Sequence, str, bytes]): The certificate or certificates
            to use to check the signature.
        verifier_cls (Optional[~google.auth.crypt.base.Signer]): Which verifier
            class to use for verification. This can be used to select different
            algorithms, such as RSA or ECDSA. Default value is :class:`RSAVerifier`.

    Returns:
        bool: True if the signature is valid, otherwise False.
    TF)Ú
isinstanceÚstrÚbytesÚfrom_stringÚverify)ÚmessageÚ	signatureÚcertsÚverifier_clsÚcertÚverifier© r   ú\/var/www/html/analyze/labelStudio/lib/python3.10/site-packages/google/auth/crypt/__init__.pyÚverify_signatureI   s   
ÿr   )Ú__doc__Úgoogle.auth.cryptr   r   r   ÚImportErrorÚ__all__r	   r
   r   r   r   r   r   r   r   r   r   Ú<module>   s&   ÿ
	