
    YPi                      :   d Z ddlZddlmZmZ ddlmZ ddlm	Z	 ddl
mZ dZ G d d	e      Z G d
 de      Z G d de      Z G d de      Z G d de      Z G d de      Z G d de      Z G d de      Z G d de      Z G d de      Z G d de      Zy)zThis module contains classes that represent Telegram errors.

.. versionchanged:: 20.0
    Replaced ``Unauthorized`` by :class:`Forbidden`.
    N)OptionalUnion)to_timedelta)get_timedelta_value)
TimePeriod)
BadRequestChatMigratedConflictEndPointNotFound	ForbiddenInvalidTokenNetworkErrorPassportDecryptionError
RetryAfterTelegramErrorTimedOutc                   `     e Zd ZdZdZdef fdZdefdZdefdZde	e
e	e   f   fdZ xZS )	r   a  
    Base class for Telegram errors.

    Tip:
        Objects of this type can be serialized via Python's :mod:`pickle` module and pickled
        objects from one version of PTB are usually loadable in future versions. However, we can
        not guarantee that this compatibility will always be provided. At least a manual one-time
        conversion of the data may be needed on major updates of the library.

    .. seealso:: :wiki:`Exceptions, Warnings and Logging <Exceptions%2C-Warnings-and-Logging>`
    messager   c                     t         |           |j                  d      }|j                  d      }|j                  d      }||k7  r|j                         }|| _        y )NzError: z	[Error]: zBad Request: )super__init__removeprefix
capitalizer   )selfr   msg	__class__s      D/root/twitch_bot/venv/lib/python3.12/site-packages/telegram/error.pyr   zTelegramError.__init__>   sX    ""9-{+/'>.."C    returnc                     | j                   S )zgGives the string representation of exceptions message.

        Returns:
           :obj:`str`
        r   r   s    r   __str__zTelegramError.__str__I   s     ||r   c                 N    | j                   j                   d| j                   dS )zmGives an unambiguous string representation of the exception.

        Returns:
           :obj:`str`
        z('z'))r   __name__r   r"   s    r   __repr__zTelegramError.__repr__Q   s&     ..))*"T\\N"==r   c                 4    | j                   | j                  ffS )zDefines how to serialize the exception for pickle.

        .. seealso::
               :py:meth:`object.__reduce__`, :mod:`pickle`.

        Returns:
            :obj:`tuple`
        r   r   r"   s    r   
__reduce__zTelegramError.__reduce__Y   s     ~~..r   )r%   
__module____qualname____doc__	__slots__strr   r#   r&   tupletyper)   __classcell__r   s   @r   r   r   /   sM    
 I	  	  ># >	/E$c
"23 	/r   r   c                       e Zd ZdZdZy)r   zRaised when the bot has not enough rights to perform the requested action.

    Examples:
        :any:`Raw API Bot <examples.rawapibot>`

    .. versionchanged:: 20.0
        This class was previously named ``Unauthorized``.
     Nr%   r*   r+   r,   r-   r4   r   r   r   r   e   s     Ir   r   c                   8     e Zd ZdZdZddee   ddf fdZ xZS )r   zRaised when the token is invalid.

    Args:
        message (:obj:`str`, optional): Any additional information about the exception.

            .. versionadded:: 20.0
    r4   Nr   r    c                 6    t         |   |d       y |       y )NzInvalid tokenr   r   r   r   r   s     r   r   zInvalidToken.__init__}   s    GOIIr   N	r%   r*   r+   r,   r-   r   r.   r   r1   r2   s   @r   r   r   r   s/     IJ J J Jr   r   c                       e Zd ZdZdZy)r   zRaised when the requested endpoint is not found. Only relevant for
    :meth:`telegram.Bot.do_api_request`.

    .. versionadded:: 20.8
    r4   Nr5   r4   r   r   r   r      s     Ir   r   c                       e Zd ZdZdZy)r   af  Base class for exceptions due to networking errors.

    Tip:
        This exception (and its subclasses) usually originates from the networking backend
        used by :class:`~telegram.request.HTTPXRequest`, or a custom implementation of
        :class:`~telegram.request.BaseRequest`. In this case, the original exception can be
        accessed via the ``__cause__``
        `attribute <https://docs.python.org/3/library/exceptions.html#exception-context>`_.

    Examples:
        :any:`Raw API Bot <examples.rawapibot>`

    .. seealso::
        :wiki:`Handling network errors <Handling-network-errors>`
    r4   Nr5   r4   r   r   r   r      s      Ir   r   c                       e Zd ZdZdZy)r   z=Raised when Telegram could not process the request correctly.r4   Nr5   r4   r   r   r   r      s
    GIr   r   c                   8     e Zd ZdZdZddee   ddf fdZ xZS )r   a  Raised when a request took too long to finish.

    .. seealso::
        :wiki:`Handling network errors <Handling-network-errors>`

    Args:
        message (:obj:`str`, optional): Any additional information about the exception.

            .. versionadded:: 20.0
    r4   Nr   r    c                 ,    t         |   |xs d       y )Nz	Timed outr8   r9   s     r   r   zTimedOut.__init__   s    /K0r   r:   r;   r2   s   @r   r   r      s+    	 I1 1 1 1r   r   c                   H     e Zd ZdZdZdef fdZdeeee   f   fdZ	 xZ
S )r	   ao  
    Raised when the requested group chat migrated to supergroup and has a new chat id.

    .. seealso::
        :wiki:`Storing Bot, User and Chat Related Data <Storing-bot%2C-user-and-chat-related-data>`

    Args:
        new_chat_id (:obj:`int`): The new chat id of the group.

    Attributes:
        new_chat_id (:obj:`int`): The new chat id of the group.

    )new_chat_idrB   c                 8    t         |   d|        || _        y )Nz+Group migrated to supergroup. New chat id: )r   r   rB   )r   rB   r   s     r   r   zChatMigrated.__init__   s     F{mTU +r   r    c                 4    | j                   | j                  ffS r:   )r   rB   r"   s    r   r)   zChatMigrated.__reduce__   s    ~~ 0 0222r   )r%   r*   r+   r,   r-   intr   r/   r0   r)   r1   r2   s   @r   r	   r	      s5     !I,C ,3E$c
"23 3r   r	   c                   |     e Zd ZdZdZdef fdZedee	e
j                  f   fd       Zdeeee   f   fdZ xZS )r   aa  
    Raised when flood limits where exceeded.

    .. versionchanged:: 20.0
       :attr:`retry_after` is now an integer to comply with the Bot API.

    Args:
        retry_after (:obj:`int` | :class:`datetime.timedelta`): Time in seconds, after which the
            bot can retry the request.

            .. versionchanged:: v22.2
                |time-period-input|

    Attributes:
        retry_after (:obj:`int` | :class:`datetime.timedelta`): Time in seconds, after which the
            bot can retry the request.

            .. deprecated:: v22.2
                |time-period-int-deprecated|

    )_retry_afterretry_afterc                     t        |      | _        t        | j                  t              rt
        |   d| j                   d       y t
        |   d| j                         y )Nz!Flood control exceeded. Retry in z seconds)r   rG   
isinstancerH   rE   r   r   )r   rH   r   s     r   r   zRetryAfter.__init__   s[    +7+Dd&&,G@AQAQ@RRZ[\G@AQAQ@TUVr   r    c                 0    t        | j                  d      S )NrH   )	attribute)r   rG   r"   s    r   rH   zRetryAfter.retry_after   s     #
 	
r   c                 b    | j                   t        | j                  j                               ffS r:   )r   rE   rG   total_secondsr"   s    r   r)   zRetryAfter.__reduce__   s*     ~~D$5$5$C$C$E FHHHr   )r%   r*   r+   r,   r-   r   r   propertyr   rE   dtm	timedeltarH   r/   r0   floatr)   r1   r2   s   @r   r   r      sb    , "IWJ W 
U3#56 
 
IE$e"45 Ir   r   c                   0    e Zd ZdZdZdeeee   f   fdZy)r
   z>Raised when a long poll or webhook conflicts with another one.r4   r    c                 4    | j                   | j                  ffS r:   r(   r"   s    r   r)   zConflict.__reduce__  s    ~~..r   N)	r%   r*   r+   r,   r-   r/   r0   r.   r)   r4   r   r   r
   r
      s$    HI/E$c
"23 /r   r
   c                   R     e Zd ZdZdZdeeef   f fdZde	e
e	e   f   fdZ xZS )r   zSomething went wrong with decryption.

    .. versionchanged:: 20.0
        This class was previously named ``TelegramDecryptionError`` and was available via
        ``telegram.TelegramDecryptionError``.
    )_msgr   c                 J    t         |   d|        t        |      | _        y )NzPassportDecryptionError: )r   r   r.   rV   r9   s     r   r   z PassportDecryptionError.__init__  s#    4WI>?L	r   r    c                 4    | j                   | j                  ffS r:   )r   rV   r"   s    r   r)   z"PassportDecryptionError.__reduce__  s    ~~		|++r   )r%   r*   r+   r,   r-   r   r.   	Exceptionr   r/   r0   r)   r1   r2   s   @r   r   r     s>     I!c9n 5 !,E$c
"23 ,r   r   )r,   datetimerP   typingr   r   telegram._utils.argumentparsingr   telegram._utils.datetimer   telegram._utils.typesr   __all__rY   r   r   r   r   r   r   r   r	   r   r
   r   r4   r   r   <module>r`      s   &  " 8 8 ,3/I 3/l
 
J= J} = ( 1| 1$3= 32+I +I\/} /,m ,r   