mirror of
https://github.com/Mayuri-Chan/pyrofork.git
synced 2025-12-29 12:04:51 +00:00
pyrofork: Add forward_media_group method
Signed-off-by: Yasir Aris M <git@yasirdev.my.id>
This commit is contained in:
parent
5b79294276
commit
ae3bc516fb
3 changed files with 123 additions and 0 deletions
|
|
@ -165,6 +165,7 @@ def pyrogram_api():
|
|||
messages="""
|
||||
Messages
|
||||
send_message
|
||||
forward_media_group
|
||||
forward_messages
|
||||
copy_message
|
||||
copy_media_group
|
||||
|
|
|
|||
|
|
@ -30,6 +30,7 @@ from .edit_message_caption import EditMessageCaption
|
|||
from .edit_message_media import EditMessageMedia
|
||||
from .edit_message_reply_markup import EditMessageReplyMarkup
|
||||
from .edit_message_text import EditMessageText
|
||||
from .forward_media_group import ForwardMediaGroup
|
||||
from .forward_messages import ForwardMessages
|
||||
from .get_available_effects import GetAvailableEffects
|
||||
from .get_chat_history import GetChatHistory
|
||||
|
|
@ -81,6 +82,7 @@ class Messages(
|
|||
EditMessageReplyMarkup,
|
||||
EditMessageMedia,
|
||||
EditMessageText,
|
||||
ForwardMediaGroup,
|
||||
ForwardMessages,
|
||||
GetAvailableEffects,
|
||||
GetMediaGroup,
|
||||
|
|
|
|||
120
pyrogram/methods/messages/forward_media_group.py
Normal file
120
pyrogram/methods/messages/forward_media_group.py
Normal file
|
|
@ -0,0 +1,120 @@
|
|||
# Pyrogram - Telegram MTProto API Client Library for Python
|
||||
# Copyright (C) 2017-present Dan <https://github.com/delivrance>
|
||||
#
|
||||
# This file is part of Pyrogram.
|
||||
#
|
||||
# Pyrogram is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU Lesser General Public License as published
|
||||
# by the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# Pyrogram is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU Lesser General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public License
|
||||
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
from datetime import datetime
|
||||
from typing import Union, List
|
||||
|
||||
import pyrogram
|
||||
from pyrogram import raw, utils
|
||||
from pyrogram import types
|
||||
|
||||
|
||||
class ForwardMediaGroup:
|
||||
async def forward_media_group(
|
||||
self: "pyrogram.Client",
|
||||
chat_id: Union[int, str],
|
||||
from_chat_id: Union[int, str],
|
||||
message_id: int,
|
||||
message_thread_id: int = None,
|
||||
disable_notification: bool = None,
|
||||
schedule_date: datetime = None,
|
||||
hide_sender_name: bool = None,
|
||||
hide_captions: bool = None,
|
||||
protect_content: bool = None
|
||||
) -> List["types.Message"]:
|
||||
"""Forward a media group by providing one of the message ids.
|
||||
|
||||
.. 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*.
|
||||
|
||||
message_thread_id (``int``, *optional*):
|
||||
Unique identifier of a message thread to which the message belongs.
|
||||
For supergroups only.
|
||||
|
||||
disable_notification (``bool``, *optional*):
|
||||
Sends the message silently.
|
||||
Users will receive a notification with no sound.
|
||||
|
||||
schedule_date (:py:obj:`~datetime.datetime`, *optional*):
|
||||
Date when the message will be automatically sent.
|
||||
|
||||
hide_sender_name (``bool``, *optional*):
|
||||
If True, the original author of the message will not be shown.
|
||||
|
||||
hide_captions (``bool``, *optional*):
|
||||
If True, the original media captions will be removed.
|
||||
|
||||
protect_content (``bool``, *optional*):
|
||||
Protects the contents of the sent message from forwarding and saving.
|
||||
|
||||
Returns:
|
||||
List of :obj:`~pyrogram.types.Message`: On success, a list of forwarded messages is returned.
|
||||
|
||||
Example:
|
||||
.. code-block:: python
|
||||
|
||||
# Forward a media group
|
||||
await app.forward_media_group(to_chat, from_chat, 123)
|
||||
"""
|
||||
message_ids = [i.id for i in await self.get_media_group(from_chat_id, message_id)]
|
||||
|
||||
r = await self.invoke(
|
||||
raw.functions.messages.ForwardMessages(
|
||||
to_peer=await self.resolve_peer(chat_id),
|
||||
from_peer=await self.resolve_peer(from_chat_id),
|
||||
id=message_ids,
|
||||
silent=disable_notification or None,
|
||||
random_id=[self.rnd_id() for _ in message_ids],
|
||||
schedule_date=utils.datetime_to_timestamp(schedule_date),
|
||||
drop_author=hide_sender_name,
|
||||
drop_media_captions=hide_captions,
|
||||
noforwards=protect_content,
|
||||
top_msg_id=message_thread_id
|
||||
)
|
||||
)
|
||||
|
||||
forwarded_messages = []
|
||||
|
||||
users = {i.id: i for i in r.users}
|
||||
chats = {i.id: i for i in r.chats}
|
||||
|
||||
for i in r.updates:
|
||||
if isinstance(i, (raw.types.UpdateNewMessage,
|
||||
raw.types.UpdateNewChannelMessage,
|
||||
raw.types.UpdateNewScheduledMessage)):
|
||||
forwarded_messages.append(
|
||||
await types.Message._parse(
|
||||
self, i.message,
|
||||
users, chats
|
||||
)
|
||||
)
|
||||
|
||||
return types.List(forwarded_messages)
|
||||
Loading…
Reference in a new issue