o
    "h2                     @   s   d Z ddlZddlmZ ddlmZmZ ddlm	Z	 ddl
mZ ddlmZmZ ddlmZ er6dd	lmZ G d
d de	ZdS )zFThis module contains an object that represents a Telegram WebhookInfo.    N)Sequence)TYPE_CHECKINGOptional)TelegramObject)parse_sequence_arg)extract_tzinfo_from_defaultsfrom_timestamp)JSONDict)Botc                       s   e Zd ZdZdZ						ddddedededee	j
 d	ee d
ee deee  dee dee	j
 dee f fddZeddeded dd f fddZ  ZS )WebhookInfoa:  This object represents a Telegram WebhookInfo.

    Contains information about the current status of a webhook.

    Objects of this class are comparable in terms of equality. Two objects of this class are
    considered equal, if their :attr:`url`, :attr:`has_custom_certificate`,
    :attr:`pending_update_count`, :attr:`ip_address`, :attr:`last_error_date`,
    :attr:`last_error_message`, :attr:`max_connections`, :attr:`allowed_updates` and
    :attr:`last_synchronization_error_date` are equal.

    .. versionchanged:: 20.0
       :attr:`last_synchronization_error_date` is considered as well when comparing objects of
       this type in terms of equality.

    Args:
        url (:obj:`str`): Webhook URL, may be empty if webhook is not set up.
        has_custom_certificate (:obj:`bool`): :obj:`True`, if a custom certificate was provided for
            webhook certificate checks.
        pending_update_count (:obj:`int`): Number of updates awaiting delivery.
        ip_address (:obj:`str`, optional): Currently used webhook IP address.
        last_error_date (:class:`datetime.datetime`): Optional. Datetime for the most recent
            error that happened when trying to deliver an update via webhook.

            .. versionchanged:: 20.3
                |datetime_localization|
        last_error_message (:obj:`str`, optional): Error message in human-readable format for the
            most recent error that happened when trying to deliver an update via webhook.
        max_connections (:obj:`int`, optional): Maximum allowed number of simultaneous HTTPS
            connections to the webhook for update delivery.
        allowed_updates (Sequence[:obj:`str`], optional): A sequence of update types the bot is
            subscribed to. Defaults to all update types, except
            :attr:`telegram.Update.chat_member`.

            .. versionchanged:: 20.0
                |sequenceclassargs|

        last_synchronization_error_date (:class:`datetime.datetime`, optional): Datetime of the
            most recent error that happened when trying to synchronize available updates with
            Telegram datacenters.

            .. versionadded:: 20.0

            .. versionchanged:: 20.3
                |datetime_localization|
    Attributes:
        url (:obj:`str`): Webhook URL, may be empty if webhook is not set up.
        has_custom_certificate (:obj:`bool`): :obj:`True`, if a custom certificate was provided for
            webhook certificate checks.
        pending_update_count (:obj:`int`): Number of updates awaiting delivery.
        ip_address (:obj:`str`): Optional. Currently used webhook IP address.
        last_error_date (:class:`datetime.datetime`): Optional. Datetime for the most recent
            error that happened when trying to deliver an update via webhook.

            .. versionchanged:: 20.3
                |datetime_localization|
        last_error_message (:obj:`str`): Optional. Error message in human-readable format for the
            most recent error that happened when trying to deliver an update via webhook.
        max_connections (:obj:`int`): Optional. Maximum allowed number of simultaneous HTTPS
            connections to the webhook for update delivery.
        allowed_updates (tuple[:obj:`str`]): Optional. A tuple of update types the bot is
            subscribed to. Defaults to all update types, except
            :attr:`telegram.Update.chat_member`.

            .. versionchanged:: 20.0

                * |tupleclassattrs|
                * |alwaystuple|
        last_synchronization_error_date (:class:`datetime.datetime`, optional): Datetime of the
            most recent error that happened when trying to synchronize available updates with
            Telegram datacenters.

            .. versionadded:: 20.0

            .. versionchanged:: 20.3
                |datetime_localization|
    )	allowed_updateshas_custom_certificate
ip_addresslast_error_datelast_error_messagelast_synchronization_error_datemax_connectionspending_update_counturlN
api_kwargsr   r   r   r   r   r   r   r   r   r   c
             	      s~   t  j|
d || _|| _|| _|| _|| _|| _|| _t	|| _
|	| _| j| j| j| j| j| j| j| j
| jf	| _|   d S )Nr   )super__init__r   r   r   r   r   r   r   r   r   r   	_id_attrs_freeze)selfr   r   r   r   r   r   r   r   r   r   	__class__ H/var/www/html/venv/lib/python3.10/site-packages/telegram/_webhookinfo.pyr   |   s,   
zWebhookInfo.__init__databotr
   returnc                    sN   |  |}t|}t|d|d|d< t|d|d|d< t j||dS )z,See :meth:`telegram.TelegramObject.de_json`.r   )tzinfor   )r    r!   )_parse_datar   r   getr   de_json)clsr    r!   
loc_tzinfor   r   r   r&      s   


zWebhookInfo.de_json)NNNNNN)N)__name__
__module____qualname____doc__	__slots__strboolintr   dtmdatetimer   r	   r   classmethodr&   __classcell__r   r   r   r   r   "   sD    M
	
,*r   )r,   r2   r1   collections.abcr   typingr   r   telegram._telegramobjectr   telegram._utils.argumentparsingr   telegram._utils.datetimer   r   telegram._utils.typesr	   telegramr
   r   r   r   r   r   <module>   s   