mirror of
https://github.com/python-telegram-bot/python-telegram-bot.git
synced 2025-01-08 19:34:12 +01:00
774 lines
29 KiB
Python
774 lines
29 KiB
Python
# python-telegram-bot - a Python interface to the Telegram Bot API
|
|
# Copyright (C) 2015-2022
|
|
# by the python-telegram-bot contributors <devs@python-telegram-bot.org>
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Lesser Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program 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 Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser Public License
|
|
# along with this program. If not, see [http://www.gnu.org/licenses/].
|
|
"""This module contains several constants that are relevant for working with the Bot API.
|
|
|
|
Unless noted otherwise, all constants in this module were extracted from the
|
|
`Telegram Bots FAQ <https://core.telegram.org/bots/faq>`_ and
|
|
`Telegram Bots API <https://core.telegram.org/bots/api>`_.
|
|
|
|
.. versionchanged:: 14.0
|
|
Since v14.0, most of the constants in this module are grouped into enums.
|
|
|
|
Attributes:
|
|
BOT_API_VERSION (:obj:`str`): `5.7`. Telegram Bot API version supported by this
|
|
version of `python-telegram-bot`. Also available as ``telegram.bot_api_version``.
|
|
|
|
.. versionadded:: 13.4
|
|
SUPPORTED_WEBHOOK_PORTS (List[:obj:`int`]): [443, 80, 88, 8443]
|
|
|
|
The following constants are related to specific classes or topics and are grouped into enums. If
|
|
they are related to a specific class, then they are also available as attributes of those classes.
|
|
"""
|
|
|
|
__all__ = [
|
|
'BOT_API_VERSION',
|
|
'BotCommandScopeType',
|
|
'CallbackQueryLimit',
|
|
'ChatAction',
|
|
'ChatID',
|
|
'ChatInviteLinkLimit',
|
|
'ChatMemberStatus',
|
|
'ChatType',
|
|
'DiceEmoji',
|
|
'FileSizeLimit',
|
|
'FloodLimit',
|
|
'InlineKeyboardMarkupLimit',
|
|
'InlineQueryLimit',
|
|
'InlineQueryResultType',
|
|
'InputMediaType',
|
|
'LocationLimit',
|
|
'MaskPosition',
|
|
'MessageAttachmentType',
|
|
'MessageEntityType',
|
|
'MessageLimit',
|
|
'MessageType',
|
|
'ParseMode',
|
|
'PollLimit',
|
|
'PollType',
|
|
'SUPPORTED_WEBHOOK_PORTS',
|
|
'UpdateType',
|
|
]
|
|
|
|
from enum import Enum, IntEnum
|
|
from typing import List
|
|
|
|
|
|
class _StringEnum(str, Enum):
|
|
"""Helper class for string enums where the value is not important to be displayed on
|
|
stringification.
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
def __repr__(self) -> str:
|
|
return f'<{self.__class__.__name__}.{self.name}>'
|
|
|
|
|
|
BOT_API_VERSION = '5.7'
|
|
|
|
# constants above this line are tested
|
|
|
|
SUPPORTED_WEBHOOK_PORTS: List[int] = [443, 80, 88, 8443]
|
|
|
|
|
|
class BotCommandScopeType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.BotCommandScope`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
DEFAULT = 'default'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeDefault`."""
|
|
ALL_PRIVATE_CHATS = 'all_private_chats'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeAllPrivateChats`."""
|
|
ALL_GROUP_CHATS = 'all_group_chats'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeAllGroupChats`."""
|
|
ALL_CHAT_ADMINISTRATORS = 'all_chat_administrators'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeAllChatAdministrators`."""
|
|
CHAT = 'chat'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeChat`."""
|
|
CHAT_ADMINISTRATORS = 'chat_administrators'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeChatAdministrators`."""
|
|
CHAT_MEMBER = 'chat_member'
|
|
""":obj:`str`: The type of :class:`telegram.BotCommandScopeChatMember`."""
|
|
|
|
|
|
class CallbackQueryLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.CallbackQuery`/
|
|
:meth:`telegram.Bot.answer_callback_query`. The enum members of this enumeration are instances
|
|
of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
ANSWER_CALLBACK_QUERY_TEXT_LENGTH = 200
|
|
""":obj:`int`: Maximum number of characters for the ``text`` parameter of
|
|
:meth:`Bot.answer_callback_query`."""
|
|
|
|
|
|
class ChatAction(_StringEnum):
|
|
"""This enum contains the available chat actions for :meth:`telegram.Bot.send_chat_action`.
|
|
The enum members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
CHOOSE_STICKER = 'choose_sticker'
|
|
""":obj:`str`: Chat action indicating that the bot is selecting a sticker."""
|
|
FIND_LOCATION = 'find_location'
|
|
""":obj:`str`: Chat action indicating that the bot is selecting a location."""
|
|
RECORD_VOICE = 'record_voice'
|
|
""":obj:`str`: Chat action indicating that the bot is recording a voice message."""
|
|
RECORD_VIDEO = 'record_video'
|
|
""":obj:`str`: Chat action indicating that the bot is recording a video."""
|
|
RECORD_VIDEO_NOTE = 'record_video_note'
|
|
""":obj:`str`: Chat action indicating that the bot is recording a video note."""
|
|
TYPING = 'typing'
|
|
""":obj:`str`: A chat indicating the bot is typing."""
|
|
UPLOAD_VOICE = 'upload_voice'
|
|
""":obj:`str`: Chat action indicating that the bot is uploading a voice message."""
|
|
UPLOAD_DOCUMENT = 'upload_document'
|
|
""":obj:`str`: Chat action indicating that the bot is uploading a document."""
|
|
UPLOAD_PHOTO = 'upload_photo'
|
|
""":obj:`str`: Chat action indicating that the bot is uploading a photo."""
|
|
UPLOAD_VIDEO = 'upload_video'
|
|
""":obj:`str`: Chat action indicating that the bot is uploading a video."""
|
|
UPLOAD_VIDEO_NOTE = 'upload_video_note'
|
|
""":obj:`str`: Chat action indicating that the bot is uploading a video note."""
|
|
|
|
|
|
class ChatID(IntEnum):
|
|
"""This enum contains some special chat IDs. The enum
|
|
members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
ANONYMOUS_ADMIN = 1087968824
|
|
""":obj:`int`: User ID in groups for messages sent by anonymous admins.
|
|
|
|
Note:
|
|
:attr:`Message.from_user` will contain this ID for backwards compatibility only. It's
|
|
recommended to use :attr:`Message.sender_chat` instead.
|
|
"""
|
|
SERVICE_CHAT = 777000
|
|
""":obj:`int`: Telegram service chat, that also acts as sender of channel posts forwarded to
|
|
discussion groups.
|
|
|
|
Note:
|
|
:attr:`Message.from_user` will contain this ID for backwards compatibility only. It's
|
|
recommended to use :attr:`Message.sender_chat` instead.
|
|
"""
|
|
FAKE_CHANNEL = 136817688
|
|
""":obj:`int`: User ID in groups when message is sent on behalf of a channel.
|
|
|
|
Note:
|
|
* :attr:`Message.from_user` will contain this ID for backwards compatibility only. It's
|
|
recommended to use :attr:`Message.sender_chat` instead.
|
|
* This value is undocumented and might be changed by Telegram.
|
|
"""
|
|
|
|
|
|
class ChatInviteLinkLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.ChatInviteLink`/
|
|
:meth:`telegram.Bot.create_chat_invite_link`/:meth:`telegram.Bot.edit_chat_invite_link`. The
|
|
enum members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
MEMBER_LIMIT = 99999
|
|
""":obj:`int`: Maximum value allowed for the ``member_limit`` parameter of
|
|
:meth:`telegram.Bot.create_chat_invite_link` and :meth:`telegram.Bot.edit_chat_invite_link`."""
|
|
NAME_LENGTH = 32
|
|
""":obj:`int`: Maximum number of characters allowed for the ``name`` parameter of
|
|
:meth:`telegram.Bot.create_chat_invite_link` and :meth:`telegram.Bot.edit_chat_invite_link`."""
|
|
|
|
|
|
class ChatMemberStatus(_StringEnum):
|
|
"""This enum contains the available states for :class:`telegram.ChatMember`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
ADMINISTRATOR = 'administrator'
|
|
""":obj:`str`: A :class:`telegram.ChatMember` who is administrator of the chat."""
|
|
CREATOR = 'creator'
|
|
""":obj:`str`: A :class:`telegram.ChatMember` who is the creator of the chat."""
|
|
KICKED = 'kicked'
|
|
""":obj:`str`: A :class:`telegram.ChatMember` who was kicked from the chat."""
|
|
LEFT = 'left'
|
|
""":obj:`str`: A :class:`telegram.ChatMember` who has left the chat."""
|
|
MEMBER = 'member'
|
|
""":obj:`str`: A :class:`telegram.ChatMember` who is a member of the chat."""
|
|
RESTRICTED = 'restricted'
|
|
""":obj:`str`: A :class:`telegram.ChatMember` who was restricted in this chat."""
|
|
|
|
|
|
class ChatType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.Chat`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
SENDER = 'sender'
|
|
""":obj:`str`: A :class:`telegram.Chat` that represents the chat of a :class:`telegram.User`
|
|
sending an :class:`telegram.InlineQuery`. """
|
|
PRIVATE = 'private'
|
|
""":obj:`str`: A :class:`telegram.Chat` that is private."""
|
|
GROUP = 'group'
|
|
""":obj:`str`: A :class:`telegram.Chat` that is a group."""
|
|
SUPERGROUP = 'supergroup'
|
|
""":obj:`str`: A :class:`telegram.Chat` that is a supergroup."""
|
|
CHANNEL = 'channel'
|
|
""":obj:`str`: A :class:`telegram.Chat` that is a channel."""
|
|
|
|
|
|
class DiceEmoji(_StringEnum):
|
|
"""This enum contains the available emoji for :class:`telegram.Dice`/
|
|
:meth:`telegram.Bot.send_dice`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
DICE = '🎲'
|
|
""":obj:`str`: A :class:`telegram.Dice` with the emoji ``🎲``."""
|
|
DARTS = '🎯'
|
|
""":obj:`str`: A :class:`telegram.Dice` with the emoji ``🎯``."""
|
|
BASKETBALL = '🏀'
|
|
""":obj:`str`: A :class:`telegram.Dice` with the emoji ``🏀``."""
|
|
FOOTBALL = '⚽'
|
|
""":obj:`str`: A :class:`telegram.Dice` with the emoji ``⚽``."""
|
|
SLOT_MACHINE = '🎰'
|
|
""":obj:`str`: A :class:`telegram.Dice` with the emoji ``🎰``."""
|
|
BOWLING = '🎳'
|
|
""":obj:`str`: A :class:`telegram.Dice` with the emoji ``🎳``."""
|
|
|
|
|
|
class FileSizeLimit(IntEnum):
|
|
"""This enum contains limitations regarding the upload and download of files. The enum
|
|
members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
FILESIZE_DOWNLOAD = int(20e6) # (20MB)
|
|
""":obj:`int`: Bots can download files of up to 20MB in size."""
|
|
FILESIZE_UPLOAD = int(50e6) # (50MB)
|
|
""":obj:`int`: Bots can upload non-photo files of up to 50MB in size."""
|
|
PHOTOSIZE_UPLOAD = int(10e6) # (10MB)
|
|
""":obj:`int`: Bots can upload photo files of up to 10MB in size."""
|
|
|
|
|
|
class FloodLimit(IntEnum):
|
|
"""This enum contains limitations regarding flood limits. The enum
|
|
members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
MESSAGES_PER_SECOND_PER_CHAT = 1
|
|
""":obj:`int`: The number of messages that can be sent per second in a particular chat.
|
|
Telegram may allow short bursts that go over this limit, but eventually you'll begin
|
|
receiving 429 errors.
|
|
"""
|
|
MESSAGES_PER_SECOND = 30
|
|
""":obj:`int`: The number of messages that can roughly be sent in an interval of 30 seconds
|
|
across all chats.
|
|
"""
|
|
MESSAGES_PER_MINUTE_PER_GROUP = 20
|
|
""":obj:`int`: The number of messages that can roughly be sent to a particular group within one
|
|
minute.
|
|
"""
|
|
|
|
|
|
class InlineKeyboardMarkupLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.InlineKeyboardMarkup`/
|
|
:meth:`telegram.Bot.send_message` & friends. The enum
|
|
members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
TOTAL_BUTTON_NUMBER = 100
|
|
""":obj:`int`: Maximum number of buttons that can be attached to a message.
|
|
|
|
Note:
|
|
This value is undocumented and might be changed by Telegram.
|
|
"""
|
|
BUTTONS_PER_ROW = 8
|
|
""":obj:`int`: Maximum number of buttons that can be attached to a message per row.
|
|
|
|
Note:
|
|
This value is undocumented and might be changed by Telegram.
|
|
"""
|
|
|
|
|
|
class InputMediaType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.InputMedia`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
ANIMATION = 'animation'
|
|
""":obj:`str`: Type of :class:`telegram.InputMediaAnimation`."""
|
|
DOCUMENT = 'document'
|
|
""":obj:`str`: Type of :class:`telegram.InputMediaDocument`."""
|
|
AUDIO = 'audio'
|
|
""":obj:`str`: Type of :class:`telegram.InputMediaAudio`."""
|
|
PHOTO = 'photo'
|
|
""":obj:`str`: Type of :class:`telegram.InputMediaPhoto`."""
|
|
VIDEO = 'video'
|
|
""":obj:`str`: Type of :class:`telegram.InputMediaVideo`."""
|
|
|
|
|
|
class InlineQueryLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.InlineQuery`/
|
|
:meth:`telegram.Bot.answer_inline_query`. The enum members of this enumeration are instances
|
|
of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
RESULTS = 50
|
|
""":obj:`int`: Maximum number of results that can be passed to
|
|
:meth:`Bot.answer_inline_query`."""
|
|
SWITCH_PM_TEXT_LENGTH = 64
|
|
""":obj:`int`: Maximum number of characters for the ``switch_pm_text`` parameter of
|
|
:meth:`Bot.answer_inline_query`."""
|
|
|
|
|
|
class InlineQueryResultType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.InlineQueryResult`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
AUDIO = 'audio'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultAudio` and
|
|
:class:`telegram.InlineQueryResultCachedAudio`.
|
|
"""
|
|
DOCUMENT = 'document'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultDocument` and
|
|
:class:`telegram.InlineQueryResultCachedDocument`.
|
|
"""
|
|
GIF = 'gif'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultGif` and
|
|
:class:`telegram.InlineQueryResultCachedGif`.
|
|
"""
|
|
MPEG4GIF = 'mpeg4_gif'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultMpeg4Gif` and
|
|
:class:`telegram.InlineQueryResultCachedMpeg4Gif`.
|
|
"""
|
|
PHOTO = 'photo'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultPhoto` and
|
|
:class:`telegram.InlineQueryResultCachedPhoto`.
|
|
"""
|
|
STICKER = 'sticker'
|
|
""":obj:`str`: Type of and :class:`telegram.InlineQueryResultCachedSticker`."""
|
|
VIDEO = 'video'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultVideo` and
|
|
:class:`telegram.InlineQueryResultCachedVideo`.
|
|
"""
|
|
VOICE = 'voice'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultVoice` and
|
|
:class:`telegram.InlineQueryResultCachedVoice`.
|
|
"""
|
|
ARTICLE = 'article'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultArticle`."""
|
|
CONTACT = 'contact'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultContact`."""
|
|
GAME = 'game'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultGame`."""
|
|
LOCATION = 'location'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultLocation`."""
|
|
VENUE = 'venue'
|
|
""":obj:`str`: Type of :class:`telegram.InlineQueryResultVenue`."""
|
|
|
|
|
|
class LocationLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.Location`/
|
|
:meth:`telegram.Bot.send_location`. The enum members of this enumeration are instances
|
|
of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
HORIZONTAL_ACCURACY = 1500
|
|
""":obj:`int`: Maximum radius of uncertainty for the location, measured in meters."""
|
|
|
|
HEADING = 360
|
|
""":obj:`int`: Maximum value allowed for the direction in which the user is moving,
|
|
in degrees.
|
|
"""
|
|
PROXIMITY_ALERT_RADIUS = 100000
|
|
""":obj:`int`: Maximum distance for proximity alerts about approaching another chat member, in
|
|
meters.
|
|
"""
|
|
|
|
|
|
class MaskPosition(_StringEnum):
|
|
"""This enum contains the available positions for :class:`telegram.MaskPosition`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
FOREHEAD = 'forehead'
|
|
""":obj:`str`: Mask position for a sticker on the forehead."""
|
|
EYES = 'eyes'
|
|
""":obj:`str`: Mask position for a sticker on the eyes."""
|
|
MOUTH = 'mouth'
|
|
""":obj:`str`: Mask position for a sticker on the mouth."""
|
|
CHIN = 'chin'
|
|
""":obj:`str`: Mask position for a sticker on the chin."""
|
|
|
|
|
|
class MessageAttachmentType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.Message` that can bee seens
|
|
as attachment. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
# Make sure that all constants here are also listed in the MessageType Enum!
|
|
# (Enums are not extendable)
|
|
|
|
ANIMATION = 'animation'
|
|
""":obj:`str`: Messages with :attr:`Message.animation`."""
|
|
AUDIO = 'audio'
|
|
""":obj:`str`: Messages with :attr:`Message.audio`."""
|
|
CONTACT = 'contact'
|
|
""":obj:`str`: Messages with :attr:`Message.contact`."""
|
|
DICE = 'dice'
|
|
""":obj:`str`: Messages with :attr:`Message.dice`."""
|
|
DOCUMENT = 'document'
|
|
""":obj:`str`: Messages with :attr:`Message.document`."""
|
|
GAME = 'game'
|
|
""":obj:`str`: Messages with :attr:`Message.game`."""
|
|
INVOICE = 'invoice'
|
|
""":obj:`str`: Messages with :attr:`Message.invoice`."""
|
|
LOCATION = 'location'
|
|
""":obj:`str`: Messages with :attr:`Message.location`."""
|
|
PASSPORT_DATA = 'passport_data'
|
|
""":obj:`str`: Messages with :attr:`Message.passport_data`."""
|
|
PHOTO = 'photo'
|
|
""":obj:`str`: Messages with :attr:`Message.photo`."""
|
|
POLL = 'poll'
|
|
""":obj:`str`: Messages with :attr:`Message.poll`."""
|
|
STICKER = 'sticker'
|
|
""":obj:`str`: Messages with :attr:`Message.sticker`."""
|
|
SUCCESSFUL_PAYMENT = 'successful_payment'
|
|
""":obj:`str`: Messages with :attr:`Message.successful_payment`."""
|
|
VIDEO = 'video'
|
|
""":obj:`str`: Messages with :attr:`Message.video`."""
|
|
VIDEO_NOTE = 'video_note'
|
|
""":obj:`str`: Messages with :attr:`Message.video_note`."""
|
|
VOICE = 'voice'
|
|
""":obj:`str`: Messages with :attr:`Message.voice`."""
|
|
VENUE = 'venue'
|
|
""":obj:`str`: Messages with :attr:`Message.venue`."""
|
|
|
|
|
|
class MessageEntityType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.MessageEntity`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
MENTION = 'mention'
|
|
""":obj:`str`: Message entities representing a mention."""
|
|
HASHTAG = 'hashtag'
|
|
""":obj:`str`: Message entities representing a hashtag."""
|
|
CASHTAG = 'cashtag'
|
|
""":obj:`str`: Message entities representing a cashtag."""
|
|
PHONE_NUMBER = 'phone_number'
|
|
""":obj:`str`: Message entities representing a phone number."""
|
|
BOT_COMMAND = 'bot_command'
|
|
""":obj:`str`: Message entities representing a bot command."""
|
|
URL = 'url'
|
|
""":obj:`str`: Message entities representing a url."""
|
|
EMAIL = 'email'
|
|
""":obj:`str`: Message entities representing a email."""
|
|
BOLD = 'bold'
|
|
""":obj:`str`: Message entities representing bold text."""
|
|
ITALIC = 'italic'
|
|
""":obj:`str`: Message entities representing italic text."""
|
|
CODE = 'code'
|
|
""":obj:`str`: Message entities representing monowidth string."""
|
|
PRE = 'pre'
|
|
""":obj:`str`: Message entities representing monowidth block."""
|
|
TEXT_LINK = 'text_link'
|
|
""":obj:`str`: Message entities representing clickable text URLs."""
|
|
TEXT_MENTION = 'text_mention'
|
|
""":obj:`str`: Message entities representing text mention for users without usernames."""
|
|
UNDERLINE = 'underline'
|
|
""":obj:`str`: Message entities representing underline text."""
|
|
STRIKETHROUGH = 'strikethrough'
|
|
""":obj:`str`: Message entities representing strikethrough text."""
|
|
SPOILER = 'spoiler'
|
|
""":obj:`str`: Message entities representing spoiler text."""
|
|
|
|
|
|
class MessageLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.Message`/
|
|
:meth:`telegram.Bot.send_message` & friends. The enum
|
|
members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
TEXT_LENGTH = 4096
|
|
""":obj:`int`: Maximum number of characters for a text message."""
|
|
CAPTION_LENGTH = 1024
|
|
""":obj:`int`: Maximum number of characters for a message caption."""
|
|
# constants above this line are tested
|
|
MESSAGE_ENTITIES = 100
|
|
""":obj:`int`: Maximum number of entities that can be displayed in a message. Further entities
|
|
will simply be ignored by Telegram.
|
|
|
|
Note:
|
|
This value is undocumented and might be changed by Telegram.
|
|
"""
|
|
|
|
|
|
class MessageType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.Message` that can be seen
|
|
as attachment. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
# Make sure that all attachment type constants are also listed in the
|
|
# MessageAttachmentType Enum! (Enums are not extendable)
|
|
|
|
# -------------------------------------------------- Attachment types
|
|
ANIMATION = 'animation'
|
|
""":obj:`str`: Messages with :attr:`Message.animation`."""
|
|
AUDIO = 'audio'
|
|
""":obj:`str`: Messages with :attr:`Message.audio`."""
|
|
CONTACT = 'contact'
|
|
""":obj:`str`: Messages with :attr:`Message.contact`."""
|
|
DICE = 'dice'
|
|
""":obj:`str`: Messages with :attr:`Message.dice`."""
|
|
DOCUMENT = 'document'
|
|
""":obj:`str`: Messages with :attr:`Message.document`."""
|
|
GAME = 'game'
|
|
""":obj:`str`: Messages with :attr:`Message.game`."""
|
|
INVOICE = 'invoice'
|
|
""":obj:`str`: Messages with :attr:`Message.invoice`."""
|
|
LOCATION = 'location'
|
|
""":obj:`str`: Messages with :attr:`Message.location`."""
|
|
PASSPORT_DATA = 'passport_data'
|
|
""":obj:`str`: Messages with :attr:`Message.passport_data`."""
|
|
PHOTO = 'photo'
|
|
""":obj:`str`: Messages with :attr:`Message.photo`."""
|
|
POLL = 'poll'
|
|
""":obj:`str`: Messages with :attr:`Message.poll`."""
|
|
STICKER = 'sticker'
|
|
""":obj:`str`: Messages with :attr:`Message.sticker`."""
|
|
SUCCESSFUL_PAYMENT = 'successful_payment'
|
|
""":obj:`str`: Messages with :attr:`Message.successful_payment`."""
|
|
VIDEO = 'video'
|
|
""":obj:`str`: Messages with :attr:`Message.video`."""
|
|
VIDEO_NOTE = 'video_note'
|
|
""":obj:`str`: Messages with :attr:`Message.video_note`."""
|
|
VOICE = 'voice'
|
|
""":obj:`str`: Messages with :attr:`Message.voice`."""
|
|
VENUE = 'venue'
|
|
""":obj:`str`: Messages with :attr:`Message.venue`."""
|
|
# -------------------------------------------------- Other types
|
|
TEXT = 'text'
|
|
""":obj:`str`: Messages with :attr:`Message.text`."""
|
|
NEW_CHAT_MEMBERS = 'new_chat_members'
|
|
""":obj:`str`: Messages with :attr:`Message.new_chat_members`."""
|
|
LEFT_CHAT_MEMBER = 'left_chat_member'
|
|
""":obj:`str`: Messages with :attr:`Message.left_chat_member`."""
|
|
NEW_CHAT_TITLE = 'new_chat_title'
|
|
""":obj:`str`: Messages with :attr:`Message.new_chat_title`."""
|
|
NEW_CHAT_PHOTO = 'new_chat_photo'
|
|
""":obj:`str`: Messages with :attr:`Message.new_chat_photo`."""
|
|
DELETE_CHAT_PHOTO = 'delete_chat_photo'
|
|
""":obj:`str`: Messages with :attr:`Message.delete_chat_photo`."""
|
|
GROUP_CHAT_CREATED = 'group_chat_created'
|
|
""":obj:`str`: Messages with :attr:`Message.group_chat_created`."""
|
|
SUPERGROUP_CHAT_CREATED = 'supergroup_chat_created'
|
|
""":obj:`str`: Messages with :attr:`Message.supergroup_chat_created`."""
|
|
CHANNEL_CHAT_CREATED = 'channel_chat_created'
|
|
""":obj:`str`: Messages with :attr:`Message.channel_chat_created`."""
|
|
MESSAGE_AUTO_DELETE_TIMER_CHANGED = 'message_auto_delete_timer_changed'
|
|
""":obj:`str`: Messages with :attr:`Message.message_auto_delete_timer_changed`."""
|
|
MIGRATE_TO_CHAT_ID = 'migrate_to_chat_id'
|
|
""":obj:`str`: Messages with :attr:`Message.migrate_to_chat_id`."""
|
|
MIGRATE_FROM_CHAT_ID = 'migrate_from_chat_id'
|
|
""":obj:`str`: Messages with :attr:`Message.migrate_from_chat_id`."""
|
|
PINNED_MESSAGE = 'pinned_message'
|
|
""":obj:`str`: Messages with :attr:`Message.pinned_message`."""
|
|
PROXIMITY_ALERT_TRIGGERED = 'proximity_alert_triggered'
|
|
""":obj:`str`: Messages with :attr:`Message.proximity_alert_triggered`."""
|
|
VOICE_CHAT_SCHEDULED = 'voice_chat_scheduled'
|
|
""":obj:`str`: Messages with :attr:`Message.voice_chat_scheduled`."""
|
|
VOICE_CHAT_STARTED = 'voice_chat_started'
|
|
""":obj:`str`: Messages with :attr:`Message.voice_chat_started`."""
|
|
VOICE_CHAT_ENDED = 'voice_chat_ended'
|
|
""":obj:`str`: Messages with :attr:`Message.voice_chat_ended`."""
|
|
VOICE_CHAT_PARTICIPANTS_INVITED = 'voice_chat_participants_invited'
|
|
""":obj:`str`: Messages with :attr:`Message.voice_chat_participants_invited`."""
|
|
|
|
|
|
class ParseMode(_StringEnum):
|
|
"""This enum contains the available parse modes. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
MARKDOWN = 'Markdown'
|
|
""":obj:`str`: Markdown parse mode.
|
|
|
|
Note:
|
|
:attr:`MARKDOWN` is a legacy mode, retained by Telegram for backward compatibility.
|
|
You should use :attr:`MARKDOWN_V2` instead.
|
|
"""
|
|
MARKDOWN_V2 = 'MarkdownV2'
|
|
""":obj:`str`: Markdown parse mode version 2."""
|
|
HTML = 'HTML'
|
|
""":obj:`str`: HTML parse mode."""
|
|
|
|
|
|
class PollLimit(IntEnum):
|
|
"""This enum contains limitations for :class:`telegram.Poll`/
|
|
:meth:`telegram.Bot.send_poll`. The enum
|
|
members of this enumeration are instances of :class:`int` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
QUESTION_LENGTH = 300
|
|
""":obj:`str`: Maximum number of characters of the polls question."""
|
|
OPTION_LENGTH = 100
|
|
""":obj:`str`: Maximum number of characters for each option for the poll."""
|
|
OPTION_NUMBER = 10
|
|
""":obj:`str`: Maximum number of available options for the poll."""
|
|
|
|
|
|
class PollType(_StringEnum):
|
|
"""This enum contains the available types for :class:`telegram.Poll`/
|
|
:meth:`telegram.Bot.send_poll`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
REGULAR = 'regular'
|
|
""":obj:`str`: regular polls."""
|
|
QUIZ = 'quiz'
|
|
""":obj:`str`: quiz polls."""
|
|
|
|
|
|
class UpdateType(_StringEnum):
|
|
"""This enum contains the available types of :class:`telegram.Update`. The enum
|
|
members of this enumeration are instances of :class:`str` and can be treated as such.
|
|
|
|
.. versionadded:: 14.0
|
|
"""
|
|
|
|
__slots__ = ()
|
|
|
|
MESSAGE = 'message'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.message`."""
|
|
EDITED_MESSAGE = 'edited_message'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.edited_message`."""
|
|
CHANNEL_POST = 'channel_post'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.channel_post`."""
|
|
EDITED_CHANNEL_POST = 'edited_channel_post'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.edited_channel_post`."""
|
|
INLINE_QUERY = 'inline_query'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.inline_query`."""
|
|
CHOSEN_INLINE_RESULT = 'chosen_inline_result'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.chosen_inline_result`."""
|
|
CALLBACK_QUERY = 'callback_query'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.callback_query`."""
|
|
SHIPPING_QUERY = 'shipping_query'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.shipping_query`."""
|
|
PRE_CHECKOUT_QUERY = 'pre_checkout_query'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.pre_checkout_query`."""
|
|
POLL = 'poll'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.poll`."""
|
|
POLL_ANSWER = 'poll_answer'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.poll_answer`."""
|
|
MY_CHAT_MEMBER = 'my_chat_member'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.my_chat_member`."""
|
|
CHAT_MEMBER = 'chat_member'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.chat_member`."""
|
|
CHAT_JOIN_REQUEST = 'chat_join_request'
|
|
""":obj:`str`: Updates with :attr:`telegram.Update.chat_join_request`."""
|