
    iq6                         S SK r S SKrS SKrS SKJr  S SKJrJrJrJrJ	r	  S SK
r
S SK
JrJrJrJrJr  S SKJr  S SKJr  \ R(                  " \5      r " S S5      rg)	    N)datetime)BinaryIOCallableListOptionalUnion)StopTransmissionenumsrawtypesutils)FilePartMissing)FileTypec            <          \ rS rSr                         S)SSS\\\4   S\\\4   S\S	\S
\S   S\	S   S\
S\S\S\SSS\S\S\
S\S\
S\SSS\S   S\S\S \S!\\\4   S"\S#\S$\	S   S%\S&\S'   4:S( jjrSrg)*SendSticker    N selfzpyrogram.Clientchat_idstickeremojicaption
parse_modezenums.ParseModecaption_entitiesztypes.MessageEntitydisable_notificationmessage_thread_iddirect_messages_topic_id	effect_idreply_parametersztypes.ReplyParametersschedule_daterepeat_periodprotect_contentbusiness_connection_idallow_paid_broadcastpaid_message_star_countsuggested_post_parametersztypes.SuggestedPostParametersreply_markup)ztypes.InlineKeyboardMarkupztypes.ReplyKeyboardMarkupztypes.ReplyKeyboardRemoveztypes.ForceReplyprogressprogress_argsreply_to_message_idreply_to_chat_idreply_to_story_id
quote_textquote_entitiesquote_offsetreturnztypes.Messagec                 	  #    [        USLUSLUSLUSLUSLUSL45      (       a  Ub  [        R                  S5        Ub  [        R                  S5        Ub  [        R                  S5        Ub  [        R                  S5        Ub  [        R                  S5        Ub  [        R                  S5        [        R                  " UUUUUUUS9nSn [        U[        5      (       GaH  [        R                  R                  U5      (       a  U R                  UUUS	9I Sh  vN n[        R                  R                  U R                  U5      =(       d    S
U[        R                  R                  [        R                  R                  U5      S9[        R                  R!                  U[        R                  R#                  5       S9/S9nGO[$        R&                  " SU5      (       a  [        R                  R)                  US9nO[*        R,                  " U[.        R0                  5      nOU R                  UUUS	9I Sh  vN n[        R                  R                  U R                  UR2                  5      =(       d    S
U[        R                  R                  UR2                  S9[        R                  R!                  U[        R                  R#                  5       S9/S9n  U R5                  U5      I Sh  vN nU R7                  [        R8                  R:                  R<                  " SUUU=(       d    S[*        R>                  " U UUU	5      I Sh  vN U RA                  5       [*        RB                  " U5      UUUUU(       a  URE                  5       OSU(       a  URE                  U 5      I Sh  vN OSU
S.[*        RF                  " XXV5      I Sh  vN D6US9I Sh  vN n[*        RH                  " U US9I Sh  vN n U (       a  U S   $ S$  GN GN GN" N Nj NI N> N#! [J         a8  n!U R                  UURL                  U!RN                  S9I Sh  vN     Sn!A!OSn!A!ff = fGM  ! [P         a     gf = f7f)a  Send static .webp or animated .tgs stickers.

.. include:: /_includes/usable-by/users-bots.rst

Parameters:
    chat_id (``int`` | ``str``):
        Unique identifier (int) or username (str) of the target chat.
        For your personal cloud (Saved Messages) you can simply use "me" or "self".
        For a contact that exists in your Telegram address book you can use his phone number (str).

    sticker (``str`` | ``BinaryIO``):
        Sticker to send.
        Pass a file_id as string to send a sticker that exists on the Telegram servers,
        pass an HTTP URL as a string for Telegram to get a .webp sticker file from the Internet,
        pass a file path as string to upload a new sticker that exists on your local machine, or
        pass a binary file-like object with its attribute ".name" set for in-memory uploads.

    emoji (``str``, *optional*):
        Emoji associated with this sticker.

    caption (``str``, *optional*):
        Sticker caption, 0-1024 characters.

    parse_mode (:obj:`~pyrogram.enums.ParseMode`, *optional*):
        By default, texts are parsed using both Markdown and HTML styles.
        You can combine both syntaxes together.

    caption_entities (List of :obj:`~pyrogram.types.MessageEntity`):
        List of special entities that appear in the caption, which can be specified instead of *parse_mode*.

    disable_notification (``bool``, *optional*):
        Sends the message silently.
        Users will receive a notification with no sound.

    message_thread_id (``int``, *optional*):
        Unique identifier for the target message thread (topic) of the forum.
        For forums only.

    direct_messages_topic_id (``int``, *optional*):
        Unique identifier of the topic in a channel direct messages chat administered by the current user.
        For directs only only.

    effect_id (``int``, *optional*):
        Unique identifier of the message effect.
        For private chats only.

    reply_parameters (:obj:`~pyrogram.types.ReplyParameters`, *optional*):
        Describes reply parameters for the message that is being sent.

    schedule_date (:py:obj:`~datetime.datetime`, *optional*):
        Date when the message will be automatically sent.

    repeat_period (``int``, *optional*):
        Period after which the message will be sent again in seconds.

    protect_content (``bool``, *optional*):
        Protects the contents of the sent message from forwarding and saving.

    business_connection_id (``str``, *optional*):
        Unique identifier of the business connection on behalf of which the message will be sent.

    allow_paid_broadcast (``bool``, *optional*):
        If True, you will be allowed to send up to 1000 messages per second.
        Ignoring broadcasting limits for a fee of 0.1 Telegram Stars per message.
        The relevant Stars will be withdrawn from the bot's balance.
        For bots only.

    paid_message_star_count (``int``, *optional*):
        The number of Telegram Stars the user agreed to pay to send the messages.

    suggested_post_parameters (:obj:`~pyrogram.types.SuggestedPostParameters`, *optional*):
        Information about the suggested post.

    reply_markup (:obj:`~pyrogram.types.InlineKeyboardMarkup` | :obj:`~pyrogram.types.ReplyKeyboardMarkup` | :obj:`~pyrogram.types.ReplyKeyboardRemove` | :obj:`~pyrogram.types.ForceReply`, *optional*):
        Additional interface options. An object for an inline keyboard, custom reply keyboard,
        instructions to remove reply keyboard or to force a reply from the user.

    progress (``Callable``, *optional*):
        Pass a callback function to view the file transmission progress.
        The function must take *(current, total)* as positional arguments (look at Other Parameters below for a
        detailed description) and will be called back each time a new file chunk has been successfully
        transmitted.

    progress_args (``tuple``, *optional*):
        Extra custom arguments for the progress callback function.
        You can pass anything you need to be available in the progress callback scope; for example, a Message
        object or a Client instance in order to edit the message with the updated progress status.

Other Parameters:
    current (``int``):
        The amount of bytes transmitted so far.

    total (``int``):
        The total size of the file.

    *args (``tuple``, *optional*):
        Extra custom arguments as defined in the ``progress_args`` parameter.
        You can either keep ``*args`` or add every single extra argument in your function signature.

Returns:
    :obj:`~pyrogram.types.Message` | ``None``: On success, the sent sticker message is returned, otherwise,
    in case the upload is deliberately stopped with :meth:`~pyrogram.Client.stop_transmission`, None is
    returned.

Example:
    .. code-block:: python

        # Send sticker by uploading from local file
        await app.send_sticker("me", "sticker.webp")

        # Send sticker using file_id
        await app.send_sticker("me", file_id)
Nzj`reply_to_message_id` is deprecated and will be removed in future updates. Use `reply_parameters` instead.zg`reply_to_chat_id` is deprecated and will be removed in future updates. Use `reply_parameters` instead.zh`reply_to_story_id` is deprecated and will be removed in future updates. Use `reply_parameters` instead.za`quote_text` is deprecated and will be removed in future updates. Use `reply_parameters` instead.ze`quote_entities` is deprecated and will be removed in future updates. Use `reply_parameters` instead.zc`quote_offset` is deprecated and will be removed in future updates. Use `reply_parameters` instead.)
message_idr   story_idquotequote_parse_moder.   quote_position)r(   r)   z
image/webp)	file_name)alt
stickerset)	mime_typefile
attributesz
^https?://)url)peermediasilentreply_to	random_idr    schedule_repeat_period
noforwardsallow_paid_floodskipallow_paid_starssuggested_postr'   effect)r#   )clientmessagesr   )file_id	file_partr   ))anylogwarningr   ReplyParameters
isinstancestrospathisfile	save_filer   InputMediaUploadedDocumentguess_mime_typeDocumentAttributeFilenamebasenameDocumentAttributeStickerInputStickerSetEmptyrematchInputMediaDocumentExternalr   get_input_media_from_file_idr   STICKERnameresolve_peerinvoke	functionsrJ   	SendMediaget_reply_tornd_iddatetime_to_timestampwriteparse_text_entitiesparse_messagesr   idvaluer	   )"r   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r;   r?   r>   rrJ   es"                                     S/app/mltbenv/lib/python3.13/site-packages/pyrogram/methods/messages/send_sticker.pysend_stickerSendSticker.send_sticker!   s8    j #4/ ,!-$&d*D(	
 	
 #. A  +} !,~ %w ){ 'y  %44.(* !+-+  E	'3''77>>'**!%(Zg!hhDII@@"&"6"6w"?"O<!II??"''JZJZ[bJc?dII>>$)+.99+I+I+K ? $ A 
E XXlG44II@@# A E ">>wHXHXYE!^^GhVc^dd		<<"227<<@PL		;;gll;S		:: %'*yy'E'E'G ;   = 
 =!%!2!27!;;D"kk..88 !%"'#7#?4+0+=+= $ 0 1 8	, & '+kkm*/*E*Em*T3@'61E-DPi+D+J+J+LosKW|/A/A$/G)G)G]a#,%& %*$=$=dZ$jj'* 0F- *  A6 &+%9%9PQ%RRH*28A;<<A i& e <& *Hj)6  S ' V..$''QWW.UUUV7 B   		s  CRAQ6  P!D#Q6 PB%Q6 +P. ?P! AP. P$AP. ;P&$<"P. P(P. +P*,P. 0Q6 P,	Q6 RQ6 RQ6 Q6 !P. $P. &P. (P. *P. ,Q6 .
Q08(Q+ Q#!Q+&Q6 +Q00Q6 6
R RRR) rt   NNNNNNNNNNNNNNNNr   NNNNNN)__name__
__module____qualname____firstlineno__r   intrR   r   r   r   boolr   r   tuplerr   __static_attributes__r       rq   r   r       s   
 268<%)!%(,48"&! $&*%)'+EI !!#',0!%6: ENNsCxN sH}%N 	N
 N ./N 45N #N N #&N N 2N  N N N  !$!N" ##N$ "%%N& $C'N( 
)N4 5N6 7N: !;N<  S/=N> ?N@ ANB 23CND ENF 
/	"GN Nr}   r   )loggingrS   r]   r   typingr   r   r   r   r   pyrogramr	   r
   r   r   r   pyrogram.errorsr   pyrogram.file_idr   	getLoggerru   rN   r   r   r}   rq   <module>r      sD   &  	 	  < <  ? ? + %!O Or}   