
    ՟f                         d Z ddlmZ ddlmZ ddlmZ ddlmZm	Z	 ddl
mZ ddlmZmZ ddlmZmZmZ  G d	 d
eeeef         Zy)z2This module contains the PaidMediaPurchased class.    )Optional)Update)DEFAULT_TRUE)SCTDVType)BaseHandler)parse_chat_idparse_username)CCTRTHandlerCallbackc                   ~     e Zd ZdZdZddefdddeeee	f   de
ee      de
ee      d	ee   f
 fd
ZdedefdZ xZS )PaidMediaPurchasedHandlerai  Handler class to handle Telegram
    :attr:`purchased paid media <telegram.Update.purchased_paid_media>`.

    .. versionadded:: 21.6

    Args:
        callback (:term:`coroutine function`): The callback function for this handler. Will be
            called when :meth:`check_update` has determined that an update should be processed by
            this handler. Callback signature::

                async def callback(update: Update, context: CallbackContext)
        user_id (:obj:`int` | Collection[:obj:`int`], optional): Filters requests to allow only
            those which are from the specified user ID(s).

        username (:obj:`str` | Collection[:obj:`str`], optional): Filters requests to allow only
            those which are from the specified username(s).

        block (:obj:`bool`, optional): Determines whether the return value of the callback should
            be awaited before processing the next handler in
            :meth:`telegram.ext.Application.process_update`. Defaults to :obj:`True`.

            .. seealso:: :wiki:`Concurrency`
    Attributes:
        callback (:term:`coroutine function`): The callback function for this handler.
        block (:obj:`bool`): Determines whether the return value of the callback should be
            awaited before processing the next handler in
            :meth:`telegram.ext.Application.process_update`.
    )	_user_ids
_usernamesNselfz"PaidMediaPurchasedHandler[CCT, RT]callbackuser_idusernameblockc                 h    t         |   ||       t        |      | _        t	        |      | _        y )N)r   )super__init__r	   r   r
   r   )r   r   r   r   r   	__class__s        k/var/www/cvtools/html/venv/lib/python3.12/site-packages/telegram/ext/_handlers/paidmediapurchasedhandler.pyr   z"PaidMediaPurchasedHandler.__init__B   s/     	/&w/(2    updatereturnc                     t        |t              r|j                  sy| j                  s| j                  sy|j                  j
                  j                  | j                  v ry|j                  j
                  j                  | j                  v S )zDetermines whether an update should be passed to this handler's :attr:`callback`.

        Args:
            update (:class:`telegram.Update` | :obj:`object`): Incoming update.

        Returns:
            :obj:`bool`

        FT)
isinstancer   purchased_paid_mediar   r   	from_useridr   )r   r   s     r   check_updatez&PaidMediaPurchasedHandler.check_updateN   sk     &&)1L1L~~doo&&0033t~~E**44==PPr   )__name__
__module____qualname____doc__	__slots__r   r   r   r   r   r   r   intstrr   boolr   objectr$   __classcell__)r   s   @r   r   r      s    :I '+'+*
32
3!&#r/2
3 #c(#
3 3s8$	
3
 d|
3Q6 Qd Qr   r   N)r(   typingr   telegramr   telegram._utils.defaultvaluer   telegram._utils.typesr   r   "telegram.ext._handlers.basehandlerr   #telegram.ext._utils._update_parsingr	   r
   telegram.ext._utils.typesr   r   r   r    r   r   <module>r7      s=   & 9   5 - : M > >@QFCO < @Qr   