aiogram/aiogram/methods/stop_message_live_location.py

34 lines
1.5 KiB
Python
Raw Normal View History

2020-06-14 18:18:29 +03:00
from __future__ import annotations
from typing import TYPE_CHECKING, Any, Dict, Optional, Union
from ..types import InlineKeyboardMarkup, Message
2019-11-14 14:44:17 +02:00
from .base import Request, TelegramMethod
if TYPE_CHECKING:
2020-06-14 18:18:29 +03:00
from ..client.bot import Bot
class StopMessageLiveLocation(TelegramMethod[Union[Message, bool]]):
"""
Use this method to stop updating a live location message before *live_period* expires. On success, if the message is not an inline message, the edited :class:`aiogram.types.message.Message` is returned, otherwise :code:`True` is returned.
Source: https://core.telegram.org/bots/api#stopmessagelivelocation
"""
__returning__ = Union[Message, bool]
chat_id: Optional[Union[int, str]] = None
"""Required if *inline_message_id* is not specified. Unique identifier for the target chat or username of the target channel (in the format :code:`@channelusername`)"""
message_id: Optional[int] = None
"""Required if *inline_message_id* is not specified. Identifier of the message with live location to stop"""
inline_message_id: Optional[str] = None
"""Required if *chat_id* and *message_id* are not specified. Identifier of the inline message"""
reply_markup: Optional[InlineKeyboardMarkup] = None
"""A JSON-serialized object for a new `inline keyboard <https://core.telegram.org/bots/features#inline-keyboards>`_."""
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()
return Request(method="stopMessageLiveLocation", data=data)