U
    ;g`$                     @   s   d dl Z d dlmZ d dlmZmZmZmZ d dl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 d d	lmZ G d
d dZdS )    N)datetime)UnionBinaryIOOptionalCallable)StopTransmission)raw)types)utils)FilePartMissing)FileTypec                   @   sV   e Zd Zddeeef eeef eeeeef eeeeed e	e
ed dd	d
ZdS )SendVideoNoter      N zpyrogram.Client)ztypes.InlineKeyboardMarkupztypes.ReplyKeyboardMarkupztypes.ReplyKeyboardRemoveztypes.ForceReplyztypes.Message)selfchat_id
video_notedurationlengththumbdisable_notificationreply_to_message_idschedule_dateprotect_contentreply_markupprogressprogress_argsreturnc                    s  d}zt |trtj|rv| |I dH }| j|||dI dH }tjj| 	|pVd||tjj
d|||dgd}qt|tj}nX| |I dH }| j|||dI dH }tjj| 	|jpd||tjj
d|||dgd}zb| tjjj| |I dH ||pd||  t||	|
r,|
| I dH nddd	I dH }W n> tk
r~ } z| j||j|jd	I dH  W 5 d}~X Y qX |jD ]j}t |tjjtjjtjjfrtjj | |j!d
d |j"D dd |j#D t |tjjdI dH   W S qqW n t$k
r   Y dS X dS )a$  Send video messages.

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

            video_note (``str`` | ``BinaryIO``):
                Video note to send.
                Pass a file_id as string to send a video note that exists on the Telegram servers,
                pass a file path as string to upload a new video note that exists on your local machine, or
                pass a binary file-like object with its attribute ".name" set for in-memory uploads.
                Sending video notes by a URL is currently unsupported.

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

            length (``int``, *optional*):
                Video width and height.

            thumb (``str`` | ``BinaryIO``, *optional*):
                Thumbnail of the video 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.

            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 video note 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 video note by uploading from local file
                await app.send_video_note("me", "video_note.mp4")

                # Set video note length
                await app.send_video_note("me", "video_note.mp4", length=25)
        N)r   r   z	video/mp4T)Zround_messager   wh)Z	mime_typefiler   
attributes )	ZpeermediaZsilentZreply_to_msg_idZ	random_idr   Z
noforwardsr   message)Zfile_idZ	file_partc                 S   s   i | ]}|j |qS r   id.0ir   r   i/opt/bot/vods_filmes/script/venv/lib/python3.8/site-packages/pyrogram/methods/messages/send_video_note.py
<dictcomp>   s      z1SendVideoNote.send_video_note.<locals>.<dictcomp>c                 S   s   i | ]}|j |qS r   r%   r'   r   r   r*   r+      s      )Zis_scheduled)%
isinstancestrospathisfileZ	save_filer   r	   ZInputMediaUploadedDocumentZguess_mime_typeZDocumentAttributeVideor
   Zget_input_media_from_file_idr   Z
VIDEO_NOTEnameZinvokeZ	functionsmessagesZ	SendMediaZresolve_peerZrnd_idZdatetime_to_timestampwriter   r&   valueZupdatesZUpdateNewMessageZUpdateNewChannelMessageZUpdateNewScheduledMessageMessage_parser$   ZusersZchatsr   )r   r   r   r   r   r   r   r   r   r   r   r   r   r    r#   rer)   r   r   r*   send_video_note!   s~    f
,

 zSendVideoNote.send_video_note)
r   r   NNNNNNNr   )__name__
__module____qualname__r   intr-   r   boolr   r   tupler   r9   r   r   r   r*   r       s8             


r   )r.   r   typingr   r   r   r   Zpyrogramr   r   r	   r
   Zpyrogram.errorsr   Zpyrogram.file_idr   r   r   r   r   r*   <module>   s   