
    i                         d 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d
S )z2This module contains the PaidMediaPurchased class.    )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         dz  de
e         dz  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                     t                                          ||           t          |          | _        t	          |          | _        d S )N)r   )super__init__r   r   r	   r   )r   r   r   r   r   	__class__s        p/Users/shanyulin/my-agent/.venv/lib/python3.11/site-packages/telegram/ext/_handlers/paidmediapurchasedhandler.pyr   z"PaidMediaPurchasedHandler.__init__@   sD     	///&w//(22    updatereturnc                     t          |t                    r|j        sdS | j        s	| j        sdS |j        j        j        | j        v rdS |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_updateL   sn     &&)) 	1L 	5~ 	do 	4&03t~EE4*4=PPr   )__name__
__module____qualname____doc__	__slots__r   r   r   r
   r   r   intstrr   boolr   objectr#   __classcell__)r   s   @r   r   r      s         :I $($(*
3 
32
3!&#r/2
3 SD
3 c(T/	
3
 d|
3 
3 
3 
3 
3 
3Q6 Qd Q Q Q Q Q Q Q Qr   r   N)r'   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>r5      s   & 9 8       5 5 5 5 5 5 - - - - - - - - : : : : : : M M M M M M M M > > > > > > > > > >@Q @Q @Q @Q @QFCO < @Q @Q @Q @Q @Qr   