2020-06-14 18:18:29 +03:00
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
|
|
from typing import TYPE_CHECKING, Any, Dict, Union
|
2019-11-03 22:14:41 +02:00
|
|
|
|
|
|
|
|
from .base import Request, TelegramMethod
|
|
|
|
|
|
2021-09-22 00:52:38 +03:00
|
|
|
if TYPE_CHECKING:
|
2020-06-14 18:18:29 +03:00
|
|
|
from ..client.bot import Bot
|
|
|
|
|
|
2019-11-03 22:14:41 +02:00
|
|
|
|
|
|
|
|
class DeleteMessage(TelegramMethod[bool]):
|
|
|
|
|
"""
|
2021-01-26 21:20:52 +02:00
|
|
|
Use this method to delete a message, including service messages, with the following limitations:
|
|
|
|
|
|
2019-11-03 22:14:41 +02:00
|
|
|
- A message can only be deleted if it was sent less than 48 hours ago.
|
2021-01-26 21:20:52 +02:00
|
|
|
|
2020-04-11 20:15:03 +03:00
|
|
|
- A dice message in a private chat can only be deleted if it was sent more than 24 hours ago.
|
2021-01-26 21:20:52 +02:00
|
|
|
|
2019-11-03 22:14:41 +02:00
|
|
|
- Bots can delete outgoing messages in private chats, groups, and supergroups.
|
2021-01-26 21:20:52 +02:00
|
|
|
|
2019-11-03 22:14:41 +02:00
|
|
|
- Bots can delete incoming messages in private chats.
|
2021-01-26 21:20:52 +02:00
|
|
|
|
|
|
|
|
- Bots granted *can_post_messages* permissions can delete outgoing messages in channels.
|
|
|
|
|
|
2019-11-03 22:14:41 +02:00
|
|
|
- If the bot is an administrator of a group, it can delete any message there.
|
2021-01-26 21:20:52 +02:00
|
|
|
|
|
|
|
|
- If the bot has *can_delete_messages* permission in a supergroup or a channel, it can delete any message there.
|
|
|
|
|
|
|
|
|
|
Returns :code:`True` on success.
|
2019-11-03 22:14:41 +02:00
|
|
|
|
|
|
|
|
Source: https://core.telegram.org/bots/api#deletemessage
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
__returning__ = bool
|
|
|
|
|
|
|
|
|
|
chat_id: Union[int, str]
|
2021-01-26 21:20:52 +02:00
|
|
|
"""Unique identifier for the target chat or username of the target channel (in the format :code:`@channelusername`)"""
|
2019-11-03 22:14:41 +02:00
|
|
|
message_id: int
|
|
|
|
|
"""Identifier of the message to delete"""
|
|
|
|
|
|
2020-06-14 18:18:29 +03:00
|
|
|
def build_request(self, bot: Bot) -> Request:
|
2019-11-14 14:44:17 +02:00
|
|
|
data: Dict[str, Any] = self.dict()
|
2019-11-14 00:44:09 +02:00
|
|
|
|
|
|
|
|
return Request(method="deleteMessage", data=data)
|