U
    ;g;                     @   s\   d dl Z d dlmZ d dlmZmZmZ d dlZd dlmZmZ e 	e
ZG dd dZdS )    N)datetime)UnionListOptional)typesenumsc                   @   sP   e Zd Zd
deeef eeef eeed ed eee	eed dddd	Z
dS )CopyMessageNzpyrogram.Clientzenums.ParseModeztypes.MessageEntity)ztypes.InlineKeyboardMarkupztypes.ReplyKeyboardMarkupztypes.ReplyKeyboardRemoveztypes.ForceReplyztypes.Message)selfchat_idfrom_chat_id
message_idcaption
parse_modecaption_entitiesdisable_notificationreply_to_message_idschedule_dateprotect_contentreply_markupreturnc                    s4   |  ||I dH }|j|||||||	|
|d	I dH S )a  Copy messages of any kind.

        The method is analogous to the method :meth:`~Client.forward_messages`, but the copied message doesn't have a
        link to the original message.

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

            from_chat_id (``int`` | ``str``):
                Unique identifier (int) or username (str) of the source chat where the original message was sent.
                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).

            message_id (``int``):
                Message identifier in the chat specified in *from_chat_id*.

            caption (``string``, *optional*):
                New caption for media, 0-1024 characters after entities parsing.
                If not specified, the original caption is kept.
                Pass "" (empty string) to remove the caption.

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

            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.

        Returns:
            :obj:`~pyrogram.types.Message`: On success, the copied message is returned.

        Example:
            .. code-block:: python

                # Copy a message
                await app.copy_message(to_chat, from_chat, 123)

        N)	r
   r   r   r   r   r   r   r   r   )Zget_messagescopy)r	   r
   r   r   r   r   r   r   r   r   r   r   message r   f/opt/bot/vods_filmes/script/venv/lib/python3.8/site-packages/pyrogram/methods/messages/copy_message.pycopy_message   s    OzCopyMessage.copy_message)NNNNNNNN)__name__
__module____qualname__r   intstrr   r   boolr   r   r   r   r   r   r      s2           

r   )loggingr   typingr   r   r   Zpyrogramr   r   	getLoggerr   logr   r   r   r   r   <module>   s   
