U
    g3                     @   s   d Z ddlmZ ddlmZmZmZmZmZ ddl	m
Z
 ddlmZmZmZ ddlmZ ddlmZ ddlmZ dd	lmZ erdd
lmZmZ G dd deZdS )zSThis module contains an object that represents a Telegram EncryptedPassportElement.    )	b64decode)TYPE_CHECKINGOptionalSequenceTupleUnion)decrypt_json)IdDocumentDataPersonalDetailsResidentialAddress)PassportFile)TelegramObject)parse_sequence_arg)JSONDict)BotCredentialsc                       s   e Zd ZdZdZdddeeeeee	e
f  ee ee eee  ee ee ee eee  ed ee d fddZedee ed	 ed  d
 fddZeee ed	 ded  d fddZ  ZS )EncryptedPassportElementa  
    Contains information about documents or other Telegram Passport elements shared with the bot
    by the user. The data has been automatically decrypted by python-telegram-bot.

    Objects of this class are comparable in terms of equality. Two objects of this class are
    considered equal, if their :attr:`type`, :attr:`data`, :attr:`phone_number`, :attr:`email`,
    :attr:`files`, :attr:`front_side`, :attr:`reverse_side` and :attr:`selfie` are equal.

    Note:
        This object is decrypted only when originating from
        :attr:`telegram.PassportData.decrypted_data`.

    Args:
        type (:obj:`str`): Element type. One of "personal_details", "passport", "driver_license",
            "identity_card", "internal_passport", "address", "utility_bill", "bank_statement",
            "rental_agreement", "passport_registration", "temporary_registration", "phone_number",
            "email".
        hash (:obj:`str`): Base64-encoded element hash for using in
            :class:`telegram.PassportElementErrorUnspecified`.
        data (:class:`telegram.PersonalDetails` | :class:`telegram.IdDocumentData` |             :class:`telegram.ResidentialAddress` | :obj:`str`, optional):
            Decrypted or encrypted data; available only for "personal_details", "passport",
            "driver_license", "identity_card", "internal_passport" and "address" types.
        phone_number (:obj:`str`, optional): User's verified phone number; available only for
            "phone_number" type.
        email (:obj:`str`, optional): User's verified email address; available only for "email"
            type.
        files (Sequence[:class:`telegram.PassportFile`], optional): Array of encrypted/decrypted
            files with documents provided by the user; available only for "utility_bill",
            "bank_statement", "rental_agreement", "passport_registration" and
            "temporary_registration" types.

            .. versionchanged:: 20.0
                |sequenceclassargs|

        front_side (:class:`telegram.PassportFile`, optional): Encrypted/decrypted file with the
            front side of the document, provided by the user; Available only for "passport",
            "driver_license", "identity_card" and "internal_passport".
        reverse_side (:class:`telegram.PassportFile`, optional): Encrypted/decrypted file with the
            reverse side of the document, provided by the user; Available only for
            "driver_license" and "identity_card".
        selfie (:class:`telegram.PassportFile`, optional): Encrypted/decrypted file with the
            selfie of the user holding a document, provided by the user; available if requested for
            "passport", "driver_license", "identity_card" and "internal_passport".
        translation (Sequence[:class:`telegram.PassportFile`], optional): Array of
            encrypted/decrypted files with translated versions of documents provided by the user;
            available if requested requested for "passport", "driver_license", "identity_card",
            "internal_passport", "utility_bill", "bank_statement", "rental_agreement",
            "passport_registration" and "temporary_registration" types.

            .. versionchanged:: 20.0
                |sequenceclassargs|

    Attributes:
        type (:obj:`str`): Element type. One of "personal_details", "passport", "driver_license",
            "identity_card", "internal_passport", "address", "utility_bill", "bank_statement",
            "rental_agreement", "passport_registration", "temporary_registration", "phone_number",
            "email".
        hash (:obj:`str`): Base64-encoded element hash for using in
            :class:`telegram.PassportElementErrorUnspecified`.
        data (:class:`telegram.PersonalDetails` | :class:`telegram.IdDocumentData` |             :class:`telegram.ResidentialAddress` | :obj:`str`):
            Optional. Decrypted or encrypted data; available only for "personal_details",
            "passport", "driver_license", "identity_card", "internal_passport" and "address" types.
        phone_number (:obj:`str`): Optional. User's verified phone number; available only for
            "phone_number" type.
        email (:obj:`str`): Optional. User's verified email address; available only for "email"
            type.
        files (Tuple[:class:`telegram.PassportFile`]): Optional. Array of encrypted/decrypted
            files with documents provided by the user; available only for "utility_bill",
            "bank_statement", "rental_agreement", "passport_registration" and
            "temporary_registration" types.

            .. versionchanged:: 20.0

                * |tupleclassattrs|
                * |alwaystuple|

        front_side (:class:`telegram.PassportFile`): Optional. Encrypted/decrypted file with the
            front side of the document, provided by the user; available only for "passport",
            "driver_license", "identity_card" and "internal_passport".
        reverse_side (:class:`telegram.PassportFile`): Optional. Encrypted/decrypted file with the
            reverse side of the document, provided by the user; available only for "driver_license"
            and "identity_card".
        selfie (:class:`telegram.PassportFile`): Optional. Encrypted/decrypted file with the
            selfie of the user holding a document, provided by the user; available if requested for
            "passport", "driver_license", "identity_card" and "internal_passport".
        translation (Tuple[:class:`telegram.PassportFile`]): Optional. Array of
            encrypted/decrypted files with translated versions of documents provided by the user;
            available if requested for "passport", "driver_license", "identity_card",
            "internal_passport", "utility_bill", "bank_statement", "rental_agreement",
            "passport_registration" and "temporary_registration" types.

            .. versionchanged:: 20.0

                * |tupleclassattrs|
                * |alwaystuple|

    )
dataemailfiles
front_sidehashphone_numberreverse_sideselfietranslationtypeN
api_kwargsr   )r   r   r   r   r   r   r   r   r   r   credentialsr   c                   s   t  j|d || _|| _|| _|| _t|| _|| _|| _	|	| _
t|
| _|| _| j| j| j| j| j| j| j	| j
f| _|   d S )Nr   )super__init__r   r   r   r   r   r   r   r   r   r   r   Z	_id_attrsZ_freeze)selfr   r   r   r   r   r   r   r   r   r   r   r   	__class__ O/tmp/pip-unpacked-wheel-swnnwir2/telegram/_passport/encryptedpassportelement.pyr!      s*    

z!EncryptedPassportElement.__init__r   )r   botreturnc                    s   |  |}|sdS t|d|p&d|d< t|d||d< t|d||d< t|d||d< t|d|pd|d< t j||dS )z,See :meth:`telegram.TelegramObject.de_json`.Nr   r   r   r   r   r   r'   )Z_parse_datar   Zde_listgetde_jsonr    )clsr   r'   r#   r%   r&   r+      s    
z EncryptedPassportElement.de_json)r   r'   r   r(   c                    sl  |sdS |d dkr\t |j|d }|jdk	rt|d tsftt|jjt|jjt|d |d< |d dkrt	j
|d |d|d< nF|d dkrtj
|d |d|d< n"|d dkrtj
|d |d|d< t|d	||jpd|d	< t|d
||j|d
< t|d||j|d< t|d||j|d< t|d||jpVd|d< t j
||dS )a  Variant of :meth:`telegram.TelegramObject.de_json` that also takes into account
        passport credentials.

        Args:
            data (Dict[:obj:`str`, ...]): The JSON data.
            bot (:class:`telegram.Bot` | :obj:`None`): The bot associated with these object.
                May be :obj:`None`, in which case shortcut methods will not be available.

                .. versionchanged:: 21.4
                   :paramref:`bot` is now optional and defaults to :obj:`None`

                .. deprecated:: 21.4
                   This argument will be converted to an optional argument in future versions.
            credentials (:class:`telegram.FileCredentials`): The credentials

        Returns:
            :class:`telegram.EncryptedPassportElement`:

        Nr   )r   r   r   Zpersonal_details)r'   )ZpassportZinternal_passportZdriver_licenseZidentity_cardaddressr   r   r   r   r   r)   )getattrsecure_datar   
isinstancedictr   r   secretr   r
   r+   r	   r   r   Zde_list_decryptedr*   r   de_json_decryptedr   r   r   r   r    )r,   r   r'   r   r/   r#   r%   r&   r3      sT    



        z*EncryptedPassportElement.de_json_decrypted)	NNNNNNNNN)N)__name__
__module____qualname____doc__	__slots__strr   r   r
   r	   r   r   r   r   r!   classmethodr+   r3   __classcell__r%   r%   r#   r&   r   "   sT   d         

/    r   N)r7   base64r   typingr   r   r   r   r   Ztelegram._passport.credentialsr   Ztelegram._passport.datar	   r
   r   Ztelegram._passport.passportfiler   Ztelegram._telegramobjectr   Ztelegram._utils.argumentparsingr   Ztelegram._utils.typesr   Ztelegramr   r   r   r%   r%   r%   r&   <module>   s   