
    kCi
                     D    S r SSKrSSKrSSKJr  SSKJr  SS jrSS jrg)zEHelper functions for loading data from a Google service account file.    N)crypt)
exceptionsc                 h   [        Ub  UO/ 5      nUR                  U R                  5       5      nU(       a4  [        R                  " SR                  SR                  U5      5      5      eU(       a!  [        R                  R                  U 5      nU$ [        R                  R                  U 5      nU$ )a  Validates a dictionary containing Google service account data.

Creates and returns a :class:`google.auth.crypt.Signer` instance from the
private key specified in the data.

Args:
    data (Mapping[str, str]): The service account data
    require (Sequence[str]): List of keys required to be present in the
        info.
    use_rsa_signer (Optional[bool]): Whether to use RSA signer or EC signer.
        We use RSA signer by default.

Returns:
    google.auth.crypt.Signer: A signer created from the private key in the
        service account file.

Raises:
    MalformedError: if the data was in the wrong format, or if one of the
        required keys is missing.
zGService account info was not in the expected format, missing fields {}.z, )set
differencekeysr   MalformedErrorformatjoinr   	RSASignerfrom_service_account_infoEsSigner)datarequireuse_rsa_signerkeys_neededmissingsigners         ]/var/www/html/land-ocr/venv/lib/python3.13/site-packages/google/auth/_service_account_info.py	from_dictr      s    * !4g"=K$$TYY[1G''		' 23
 	
 ::4@ M 99$?M    c                     [         R                  " U SSS9 n[        R                  " U5      nU[	        XAUS94sSSS5        $ ! , (       d  f       g= f)a  Reads a Google service account JSON file and returns its parsed info.

Args:
    filename (str): The path to the service account .json file.
    require (Sequence[str]): List of keys required to be present in the
        info.
    use_rsa_signer (Optional[bool]): Whether to use RSA signer or EC signer.
        We use RSA signer by default.

Returns:
    Tuple[ Mapping[str, str], google.auth.crypt.Signer ]: The verified
        info and a signer instance.
rzutf-8)encoding)r   r   N)ioopenjsonloadr   )filenamer   r   	json_filer   s        r   from_filenamer!   @   s?     
3	1Yyy#Yt^TT 
2	1	1s   "A
A)NT)__doc__r   r   google.authr   r   r   r!    r   r   <module>r%      s#    L 	   "%PUr   