
    N[i$                         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  G d	 d
      Zy)    N)datetime)UnionBinaryIOListOptionalCallable)rawenums)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   d	ed
   de	dede	dede
de	ded   dededed   f dZy)	SendPhotoNselfzpyrogram.Clientchat_idphotocaption
parse_modezenums.ParseModecaption_entitiesztypes.MessageEntityhas_spoilerttl_seconds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              rt        j                  j	                  |      r?| j                  |||       d{   }t        j                  j                  |||      }nt        j                  d|      r#t        j                  j                  |||      }net        j                  |t        j                  |      }n>| j                  |||       d{   }t        j                  j                  |||      }	 	 | j!                  t        j"                  j$                  j&                  d
| j)                  |       d{   ||xs d|	| j+                         t        j,                  |
      ||r|j/                  |        d{   nddt        j0                  | |||       d{          d{   }|j2                  D ]  }t        |t        j                  j4                  t        j                  j6                  t        j                  j8                  f      s[t        j:                  j=                  | |j>                  |j@                  D ci c]  }|jB                  | c}|jD                  D ci c]  }|jB                  | c}t        t        j                  j8                               d{   c S  	 7 7 7 7 J7 *7 c c}w c c}w 7 &# tF        $ r;}| j                  ||jB                  |jH                  	       d{  7   Y d}~_d}~ww xY w# tJ        jL                  $ r Y yw xY ww)a5  Send photos.

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

            photo (``str`` | ``BinaryIO``):
                Photo to send.
                Pass a file_id as string to send a photo that exists on the Telegram servers,
                pass an HTTP URL as a string for Telegram to get a photo from the Internet,
                pass a file path as string to upload a new photo 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*):
                Photo 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*.

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

            ttl_seconds (``int``, *optional*):
                Self-Destruct Timer.
                If you set a timer, the photo will self-destruct in *ttl_seconds*
                seconds after it was viewed.

            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 photo 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 photo by uploading from local file
                await app.send_photo("me", "photo.jpg")

                # Send photo by uploading from URL
                await app.send_photo("me", "https://example.com/example.jpg")

                # Add caption to a photo
                await app.send_photo("me", "photo.jpg", caption="Caption")

                # Send self-destructing photo
                await app.send_photo("me", "photo.jpg", ttl_seconds=10)
        N)r   r   )filer   spoilerz
^https?://)urlr   r#   )r   )peermediasilentreply_to_msg_id	random_idr   
noforwardsr   )is_scheduled)file_id	file_part )'
isinstancestrospathisfile	save_filer	   r   InputMediaUploadedPhotorematchInputMediaPhotoExternalr   get_input_media_from_file_idr   PHOTOinvoke	functionsmessages	SendMediaresolve_peerrnd_iddatetime_to_timestampwriteparse_text_entitiesupdatesUpdateNewMessageUpdateNewChannelMessageUpdateNewScheduledMessageMessage_parsemessageusersidchatsr   valuepyrogramStopTransmission)r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r"   r&   ries                       W/var/www/files/kim/lib/python3.12/site-packages/pyrogram/methods/messages/send_photo.py
send_photozSendPhoto.send_photo!   s    f 6	%%77>>%(!%Xe!ffDII==!$/ + > E
 XXlE2II==!$/ + > E ">>uhnnbmnE!^^EHTa^bb		99 +' :  "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 */)=)= $aii23'' :Qq :23'' :Qq :-7399;^;^-_	 *> * $ 		% - g c "B *Hj, !; :$ ' T..177.SSST (( 		s   MAM KBM +K ,'M AK; K#AK; K&"K; ?K) K; K,K; A&M 93M ,K/ M K4$.M K9M MM  M #K; &K; )K; ,K; /M ;	L?+L:/L20L:5M :L??M MMMM) NNNNNNNNNNr.   )__name__
__module____qualname__r   intr0   r   r   r   boolr   r   tuplerU   r.       rT   r   r       s   
 268< %)#'"& $ !!)kksCxk S(]#k 	k
 ./k 45k k k #k !k  k k 
k& 'k( )k* 
/	"+kr]   r   )r1   r6   r   typingr   r   r   r   r   rO   r	   r
   r   r   pyrogram.errorsr   pyrogram.file_idr   r   r.   r]   rT   <module>ra      s4   & 
 	  < <     + %l lr]   