
    N[i(1                         d dl Z d dlZd dlmZ d dlmZmZmZmZm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 dlmZ d d	lmZ  G d
 d      Zy)    N)datetime)UnionBinaryIOListOptionalCallable)StopTransmissionenums)raw)types)utils)FilePartMissing)FileTypec            ,           e Zd Z	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddddeeef   deeef   dededed	   d
e	d   dededededeeef   dededede
deded   dededed   f*dZy)SendAnimationNselfzpyrogram.Clientchat_id	animationcaptionunsave
parse_modezenums.ParseModecaption_entitiesztypes.MessageEntityhas_spoilerdurationwidthheightthumb	file_namedisable_notificationreply_to_message_idschedule_dateprotect_contentreply_markup)ztypes.InlineKeyboardMarkupztypes.ReplyKeyboardMarkupztypes.ReplyKeyboardRemoveztypes.ForceReplyprogressprogress_argsreturnztypes.Messagec                 
  K   d}	 t        |t              rjt        j                  j	                  |      r| j                  |       d{   }| j                  |||       d{   }t        j                  j                  | j                  |      xs d|||t        j                  j                  d||	|
      t        j                  j                  |xs t        j                  j                  |            t        j                  j                         g      }nDt        j                  d|      r#t        j                  j!                  ||	      }nt#        j$                  |t&        j(                        }n| j                  |       d{   }| j                  |||       d{   }t        j                  j                  | j                  |xs |j*                        xs d|||t        j                  j                  d||	|
      t        j                  j                  |xs |j*                        t        j                  j                         g      }	 	 | j-                  t        j.                  j0                  j2                  d| j5                  |       d{   ||xs d|| j7                         t#        j8                  |      ||r|j;                  |        d{   ndd
t#        j<                  | |||       d{          d{   }|j>                  D ]  }t        |t        j                  j@                  t        j                  jB                  t        j                  jD                  f      s\t        jF                  jI                  | |jJ                  |jL                  D ci c]  }|jN                  | c}|jP                  D ci c]  }|jN                  | c}t        t        j                  jD                               d{   }|r|jR                  xs |jT                  }t#        j$                  |jV                  t&        j(                        jN                  }| j-                  t        j.                  j0                  jY                  |d             d{    |c S  	 c7 7 h7 <7 #7 +7 7 7 c c}w c c}w 7 7 0# tZ        $ r;}| j                  ||jN                  |j\                         d{  7   Y d}~gd}~ww xY w# t^        $ r Y yw xY ww)aV  Send animation files (animation or H.264/MPEG-4 AVC video without sound).

        .. 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).

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

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

            unsave (``bool``, *optional*):
                By default, the server will save into your own collection any new animation you send.
                Pass True to automatically unsave the sent animation. Defaults to False.

            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*.

            has_spoiler (``bool``, *optional*):
                Pass True if the animation needs to be covered with a spoiler animation.

            duration (``int``, *optional*):
                Duration of sent animation in seconds.

            width (``int``, *optional*):
                Animation width.

            height (``int``, *optional*):
                Animation height.

            thumb (``str`` | ``BinaryIO``, *optional*):
                Thumbnail of the animation file sent.
                The thumbnail should be in JPEG format and less than 200 KB in size.
                A thumbnail's width and height should not exceed 320 pixels.
                Thumbnails can't be reused and can be only uploaded as a new file.

            file_name (``str``, *optional*):
                File name of the animation sent.
                Defaults to file's path basename.

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

            reply_to_message_id (``int``, *optional*):
                If the message is a reply, ID of the original message.

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

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

            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 animation 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 animation by uploading from local file
                await app.send_animation("me", "animation.gif")

                # Add caption to the animation
                await app.send_animation("me", "animation.gif", caption="animation caption")

                # Unsave the animation once is sent
                await app.send_animation("me", "animation.gif", unsave=True)

                # Keep track of the progress while uploading
                async def progress(current, total):
                    print(f"{current * 100 / total:.1f}%")

                await app.send_animation("me", "animation.gif", progress=progress)
        N)r$   r%   z	video/mp4T)supports_streamingr   wh)r   )	mime_typefiler   spoiler
attributesz
^https?://)urlr-   )peermediasilentreply_to_msg_id	random_idr!   
noforwardsr#   )is_scheduled)idr   )file_id	file_part )0
isinstancestrospathisfile	save_filer   r   InputMediaUploadedDocumentguess_mime_typeDocumentAttributeVideoDocumentAttributeFilenamebasenameDocumentAttributeAnimatedrematchInputMediaDocumentExternalr   get_input_media_from_file_idr   	ANIMATIONnameinvoke	functionsmessages	SendMediaresolve_peerrnd_iddatetime_to_timestampwriteparse_text_entitiesupdatesUpdateNewMessageUpdateNewChannelMessageUpdateNewScheduledMessageMessage_parsemessageusersr7   chatsr   documentr8   SaveGifr   valuer	   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r,   r1   rir\   r_   document_ides                               [/var/www/files/kim/lib/python3.12/site-packages/pyrogram/methods/messages/send_animation.pysend_animationzSendAnimation.send_animation"   s{    \ ]	)S)77>>),"&.."77E!%	H\i!jjDII@@"&"6"6y"A"P[!# +II<<37)1"'"(	 =   II??)JrWYW^W^WgWghqWr?sII??A	$ A E  XXlI6II@@% + A E
 ">>y(J\J\]E"nnU33!^^IXe^ff		<<"2293N	O^S^'		88/3%-#$	 9  		;;iFaS\SaSa;b		;;=	  = " )+"kk..88 
'+'8'8'A!A"'#7#?4,?&*kkm*/*E*Em*T'6KW|/A/A$/G)G)G]a
 %*$=$=dGZYi$jj
 A  YY +%a#))*D*D*-))*K*K*-))*M*M*O P -2MM,@,@ $aii23'' :Qq :23'' :Qq :-7399;^;^-_	 -A - 'G  &+2+<+<+P@P@P.3.P.P$,$4$4h6H6H/""$" !, '+kk$'MM$:$:$B$B+6/3 %C %&'" !" !" $+N1+% [ 8j2 4f, "B *Hj, !; :'!") ' X..DGGqww.WWWX:   		s7  UAT8 
ST8 &S'D.T8 ST8 1S2B6T8 )AS1 ,S-AS1 1S2"S1 SS1 "S #S1 'A'T8 3T8 S#T8 &S(:.T8 (S-)BT8 >S/?T8 UT8 T8 T8 T8 S1 S1 S1  S1 #T8 /T8 1	T5:+T0%T(&T0+T8 0T55T8 8	UUUU) FNNNr   r   r   NNNNNNNNr:   )__name__
__module____qualname__r   intr<   r   boolr   r   r   r   tuplerg   r:       rf   r   r   !   sW   
 268< &*%)#'"& $ !!3mmsCxm h'm 	m
 m ./m 45m m m m m S(]#m m #m !m   !m" #m$ 
%m0 1m2 3m4 
/	"5mro   r   )r=   rG   r   typingr   r   r   r   r   pyrogramr	   r
   r   r   r   pyrogram.errorsr   pyrogram.file_idr   r   r:   ro   rf   <module>rt      s7   & 
 	  < <  ,    + %n nro   