2021-06-06 11:48:48 +02:00
|
|
|
#!/usr/bin/env python
|
2022-05-05 09:27:54 +02:00
|
|
|
# pylint: disable=too-many-arguments
|
2021-06-06 11:48:48 +02:00
|
|
|
#
|
|
|
|
# A library that provides a Python interface to the Telegram Bot API
|
2022-01-03 08:15:18 +01:00
|
|
|
# Copyright (C) 2015-2022
|
2021-06-06 11:48:48 +02:00
|
|
|
# Leandro Toledo de Souza <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 an object that represents a Telegram Bot with convenience extensions."""
|
|
|
|
from copy import copy
|
2021-10-03 15:10:13 +02:00
|
|
|
from datetime import datetime
|
|
|
|
from typing import (
|
2022-05-05 09:27:54 +02:00
|
|
|
TYPE_CHECKING,
|
2021-10-03 15:10:13 +02:00
|
|
|
Callable,
|
2022-05-05 09:27:54 +02:00
|
|
|
Dict,
|
2022-08-26 06:50:03 +02:00
|
|
|
Generic,
|
2022-05-05 09:27:54 +02:00
|
|
|
List,
|
2021-10-03 15:10:13 +02:00
|
|
|
Optional,
|
2022-05-05 09:27:54 +02:00
|
|
|
Sequence,
|
2021-10-03 15:10:13 +02:00
|
|
|
Tuple,
|
|
|
|
TypeVar,
|
2022-05-05 09:27:54 +02:00
|
|
|
Union,
|
|
|
|
cast,
|
2021-10-03 15:10:13 +02:00
|
|
|
no_type_check,
|
2022-08-26 06:50:03 +02:00
|
|
|
overload,
|
2021-10-03 15:10:13 +02:00
|
|
|
)
|
2022-08-26 06:50:03 +02:00
|
|
|
from uuid import uuid4
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
from telegram import (
|
2022-08-26 06:50:03 +02:00
|
|
|
Animation,
|
|
|
|
Audio,
|
2021-10-10 15:10:21 +02:00
|
|
|
Bot,
|
2022-08-26 06:50:03 +02:00
|
|
|
BotCommand,
|
|
|
|
BotCommandScope,
|
2022-05-05 09:27:54 +02:00
|
|
|
CallbackQuery,
|
|
|
|
Chat,
|
2022-08-26 06:50:03 +02:00
|
|
|
ChatAdministratorRights,
|
|
|
|
ChatInviteLink,
|
|
|
|
ChatMember,
|
|
|
|
ChatPermissions,
|
|
|
|
ChatPhoto,
|
|
|
|
Contact,
|
|
|
|
Document,
|
|
|
|
File,
|
|
|
|
GameHighScore,
|
2021-06-06 11:48:48 +02:00
|
|
|
InlineKeyboardMarkup,
|
2022-05-05 09:27:54 +02:00
|
|
|
InputMedia,
|
2022-08-26 06:50:03 +02:00
|
|
|
Location,
|
|
|
|
MaskPosition,
|
|
|
|
MenuButton,
|
2022-05-05 09:27:54 +02:00
|
|
|
Message,
|
2021-06-06 11:48:48 +02:00
|
|
|
MessageId,
|
2022-08-26 06:50:03 +02:00
|
|
|
PassportElementError,
|
|
|
|
PhotoSize,
|
2022-05-05 09:27:54 +02:00
|
|
|
Poll,
|
2022-08-26 06:50:03 +02:00
|
|
|
SentWebAppMessage,
|
|
|
|
ShippingOption,
|
|
|
|
Sticker,
|
|
|
|
StickerSet,
|
2021-06-06 11:48:48 +02:00
|
|
|
Update,
|
2022-08-26 06:50:03 +02:00
|
|
|
User,
|
|
|
|
UserProfilePhotos,
|
|
|
|
Venue,
|
|
|
|
Video,
|
|
|
|
VideoNote,
|
|
|
|
Voice,
|
|
|
|
WebhookInfo,
|
2021-06-06 11:48:48 +02:00
|
|
|
)
|
2021-10-10 15:10:21 +02:00
|
|
|
from telegram._utils.datetime import to_timestamp
|
2022-05-05 09:27:54 +02:00
|
|
|
from telegram._utils.defaultvalue import DEFAULT_NONE, DefaultValue
|
2022-08-26 06:50:03 +02:00
|
|
|
from telegram._utils.types import DVInput, FileInput, JSONDict, ODVInput, ReplyMarkup
|
2021-10-10 15:10:21 +02:00
|
|
|
from telegram.ext._callbackdatacache import CallbackDataCache
|
2022-08-26 06:50:03 +02:00
|
|
|
from telegram.ext._utils.types import RLARGS
|
2022-04-24 12:38:09 +02:00
|
|
|
from telegram.request import BaseRequest
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
if TYPE_CHECKING:
|
2022-08-26 06:50:03 +02:00
|
|
|
from telegram import (
|
|
|
|
InlineQueryResult,
|
|
|
|
InputMediaAudio,
|
|
|
|
InputMediaDocument,
|
|
|
|
InputMediaPhoto,
|
|
|
|
InputMediaVideo,
|
|
|
|
LabeledPrice,
|
|
|
|
MessageEntity,
|
|
|
|
)
|
|
|
|
from telegram.ext import BaseRateLimiter, Defaults
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
HandledTypes = TypeVar("HandledTypes", bound=Union[Message, CallbackQuery, Chat])
|
|
|
|
|
|
|
|
|
2022-08-26 06:50:03 +02:00
|
|
|
class ExtBot(Bot, Generic[RLARGS]):
|
2021-06-06 11:48:48 +02:00
|
|
|
"""This object represents a Telegram Bot with convenience extensions.
|
|
|
|
|
|
|
|
Warning:
|
|
|
|
Not to be confused with :class:`telegram.Bot`.
|
|
|
|
|
|
|
|
For the documentation of the arguments, methods and attributes, please see
|
|
|
|
:class:`telegram.Bot`.
|
|
|
|
|
2022-08-26 06:50:03 +02:00
|
|
|
All API methods of this class have an additional keyword argument ``rate_limit_args``.
|
|
|
|
This can be used to pass additional information to the rate limiter, specifically to
|
|
|
|
:paramref:`telegram.ext.BaseRateLimiter.process_request.rate_limit_args`.
|
|
|
|
|
|
|
|
Warning:
|
|
|
|
* The keyword argument ``rate_limit_args`` can `not` be used, if :attr:`rate_limiter`
|
|
|
|
is :obj:`None`.
|
|
|
|
* The method :meth:`~telegram.Bot.get_updates` is the only method that does not have the
|
|
|
|
additional argument, as this method will never be rate limited.
|
|
|
|
|
2022-08-27 11:46:51 +02:00
|
|
|
.. seealso:: `Arbitrary Callback Example <examples.arbitrarycallbackdatabot.html>`_,
|
|
|
|
`Arbitrary callback_data <https://github.com/python-telegram-bot/
|
|
|
|
python-telegram-bot/wiki/Arbitrary-callback_data>`_
|
|
|
|
|
2021-06-06 11:48:48 +02:00
|
|
|
.. versionadded:: 13.6
|
|
|
|
|
2022-10-07 10:18:08 +02:00
|
|
|
.. versionchanged:: 20.0
|
|
|
|
Removed the attribute ``arbitrary_callback_data``. You can instead use
|
|
|
|
:attr:`bot.callback_data_cache.maxsize <telegram.ext.CallbackDataCache.maxsize>` to
|
|
|
|
access the size of the cache.
|
|
|
|
|
2021-06-06 11:48:48 +02:00
|
|
|
Args:
|
|
|
|
defaults (:class:`telegram.ext.Defaults`, optional): An object containing default values to
|
|
|
|
be used if not set explicitly in the bot methods.
|
|
|
|
arbitrary_callback_data (:obj:`bool` | :obj:`int`, optional): Whether to
|
|
|
|
allow arbitrary objects as callback data for :class:`telegram.InlineKeyboardButton`.
|
|
|
|
Pass an integer to specify the maximum number of objects cached in memory. For more
|
2022-01-21 16:51:03 +01:00
|
|
|
details, please see our `wiki <https://github.com/python-telegram-bot\
|
|
|
|
/python-telegram-bot/wiki/Arbitrary-callback_data>`_. Defaults to :obj:`False`.
|
2022-08-26 06:50:03 +02:00
|
|
|
rate_limiter (:class:`telegram.ext.BaseRateLimiter`, optional): A rate limiter to use for
|
|
|
|
limiting the number of requests made by the bot per time interval.
|
|
|
|
|
|
|
|
.. versionadded:: 20.0
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
"""
|
|
|
|
|
2022-10-07 10:18:08 +02:00
|
|
|
__slots__ = ("_callback_data_cache", "_defaults", "_rate_limiter")
|
2022-08-26 06:50:03 +02:00
|
|
|
|
|
|
|
# using object() would be a tiny bit safer, but a string plays better with the typing setup
|
|
|
|
__RL_KEY = uuid4().hex
|
|
|
|
|
|
|
|
@overload
|
|
|
|
def __init__(
|
|
|
|
self: "ExtBot[None]",
|
|
|
|
token: str,
|
|
|
|
base_url: str = "https://api.telegram.org/bot",
|
|
|
|
base_file_url: str = "https://api.telegram.org/file/bot",
|
|
|
|
request: BaseRequest = None,
|
|
|
|
get_updates_request: BaseRequest = None,
|
|
|
|
private_key: bytes = None,
|
|
|
|
private_key_password: bytes = None,
|
|
|
|
defaults: "Defaults" = None,
|
|
|
|
arbitrary_callback_data: Union[bool, int] = False,
|
2022-09-19 22:31:23 +02:00
|
|
|
local_mode: bool = False,
|
2022-08-26 06:50:03 +02:00
|
|
|
):
|
|
|
|
...
|
|
|
|
|
|
|
|
@overload
|
|
|
|
def __init__(
|
|
|
|
self: "ExtBot[RLARGS]",
|
|
|
|
token: str,
|
|
|
|
base_url: str = "https://api.telegram.org/bot",
|
|
|
|
base_file_url: str = "https://api.telegram.org/file/bot",
|
|
|
|
request: BaseRequest = None,
|
|
|
|
get_updates_request: BaseRequest = None,
|
|
|
|
private_key: bytes = None,
|
|
|
|
private_key_password: bytes = None,
|
|
|
|
defaults: "Defaults" = None,
|
|
|
|
arbitrary_callback_data: Union[bool, int] = False,
|
2022-09-19 22:31:23 +02:00
|
|
|
local_mode: bool = False,
|
2022-08-26 06:50:03 +02:00
|
|
|
rate_limiter: "BaseRateLimiter[RLARGS]" = None,
|
|
|
|
):
|
|
|
|
...
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
token: str,
|
2021-10-09 13:56:50 +02:00
|
|
|
base_url: str = "https://api.telegram.org/bot",
|
|
|
|
base_file_url: str = "https://api.telegram.org/file/bot",
|
2022-04-24 12:38:09 +02:00
|
|
|
request: BaseRequest = None,
|
|
|
|
get_updates_request: BaseRequest = None,
|
2021-06-06 11:48:48 +02:00
|
|
|
private_key: bytes = None,
|
|
|
|
private_key_password: bytes = None,
|
|
|
|
defaults: "Defaults" = None,
|
|
|
|
arbitrary_callback_data: Union[bool, int] = False,
|
2022-09-19 22:31:23 +02:00
|
|
|
local_mode: bool = False,
|
2022-08-26 06:50:03 +02:00
|
|
|
rate_limiter: "BaseRateLimiter" = None,
|
2021-06-06 11:48:48 +02:00
|
|
|
):
|
|
|
|
super().__init__(
|
|
|
|
token=token,
|
|
|
|
base_url=base_url,
|
|
|
|
base_file_url=base_file_url,
|
|
|
|
request=request,
|
2022-04-24 12:38:09 +02:00
|
|
|
get_updates_request=get_updates_request,
|
2021-06-06 11:48:48 +02:00
|
|
|
private_key=private_key,
|
|
|
|
private_key_password=private_key_password,
|
2022-09-19 22:31:23 +02:00
|
|
|
local_mode=local_mode,
|
2021-06-06 11:48:48 +02:00
|
|
|
)
|
2021-10-03 15:10:13 +02:00
|
|
|
self._defaults = defaults
|
2022-08-26 06:50:03 +02:00
|
|
|
self._rate_limiter = rate_limiter
|
2022-10-07 10:18:08 +02:00
|
|
|
self._callback_data_cache: Optional[CallbackDataCache] = None
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
# set up callback_data
|
2022-10-07 10:18:08 +02:00
|
|
|
if arbitrary_callback_data is False:
|
|
|
|
return
|
|
|
|
|
2021-06-06 11:48:48 +02:00
|
|
|
if not isinstance(arbitrary_callback_data, bool):
|
|
|
|
maxsize = cast(int, arbitrary_callback_data)
|
|
|
|
else:
|
|
|
|
maxsize = 1024
|
2022-10-07 10:18:08 +02:00
|
|
|
|
|
|
|
self._callback_data_cache = CallbackDataCache(bot=self, maxsize=maxsize)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def callback_data_cache(self) -> Optional[CallbackDataCache]:
|
|
|
|
""":class:`telegram.ext.CallbackDataCache`: Optional. The cache for
|
|
|
|
objects passed as callback data for :class:`telegram.InlineKeyboardButton`.
|
|
|
|
|
|
|
|
.. versionchanged:: 20.0
|
|
|
|
* This property is now read-only.
|
|
|
|
* This property is now optional and can be :obj:`None` if
|
|
|
|
:paramref:`~telegram.ext.ExtBot.arbitrary_callback_data` is set to :obj:`False`.
|
|
|
|
"""
|
|
|
|
return self._callback_data_cache
|
2021-06-06 11:48:48 +02:00
|
|
|
|
2022-08-26 06:50:03 +02:00
|
|
|
async def initialize(self) -> None:
|
|
|
|
"""See :meth:`telegram.Bot.initialize`. Also initializes the
|
|
|
|
:paramref:`ExtBot.rate_limiter` (if set)
|
|
|
|
by calling :meth:`telegram.ext.BaseRateLimiter.initialize`.
|
|
|
|
"""
|
|
|
|
# Initialize before calling super, because super calls get_me
|
|
|
|
if self.rate_limiter:
|
|
|
|
await self.rate_limiter.initialize()
|
|
|
|
await super().initialize()
|
|
|
|
|
|
|
|
async def shutdown(self) -> None:
|
|
|
|
"""See :meth:`telegram.Bot.shutdown`. Also shuts down the
|
|
|
|
:paramref:`ExtBot.rate_limiter` (if set) by
|
|
|
|
calling :meth:`telegram.ext.BaseRateLimiter.shutdown`.
|
|
|
|
"""
|
|
|
|
# Shut down the rate limiter before shutting down the request objects!
|
|
|
|
if self.rate_limiter:
|
|
|
|
await self.rate_limiter.shutdown()
|
|
|
|
await super().shutdown()
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def _merge_api_rl_kwargs(
|
|
|
|
cls, api_kwargs: Optional[JSONDict], rate_limit_args: Optional[RLARGS]
|
|
|
|
) -> Optional[JSONDict]:
|
|
|
|
"""Inserts the `rate_limit_args` into `api_kwargs` with the special key `__RL_KEY` so
|
|
|
|
that we can extract them later without having to modify the `telegram.Bot` class.
|
|
|
|
"""
|
|
|
|
if not rate_limit_args:
|
|
|
|
return api_kwargs
|
|
|
|
if api_kwargs is None:
|
|
|
|
api_kwargs = {}
|
|
|
|
api_kwargs[cls.__RL_KEY] = rate_limit_args
|
|
|
|
return api_kwargs
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def _extract_rl_kwargs(cls, data: Optional[JSONDict]) -> Optional[RLARGS]:
|
|
|
|
"""Extracts the `rate_limit_args` from `data` if it exists."""
|
|
|
|
if not data:
|
|
|
|
return None
|
|
|
|
return data.pop(cls.__RL_KEY, None)
|
|
|
|
|
|
|
|
async def _do_post(
|
|
|
|
self,
|
|
|
|
endpoint: str,
|
|
|
|
data: JSONDict,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
) -> Union[bool, JSONDict, None]:
|
|
|
|
"""Order of method calls is: Bot.some_method -> Bot._post -> Bot._do_post.
|
|
|
|
So we can override Bot._do_post to add rate limiting.
|
|
|
|
"""
|
|
|
|
rate_limit_args = self._extract_rl_kwargs(data)
|
|
|
|
if not self.rate_limiter and rate_limit_args is not None:
|
|
|
|
raise ValueError(
|
|
|
|
"`rate_limit_args` can only be used if a `ExtBot.rate_limiter` is set."
|
|
|
|
)
|
|
|
|
|
|
|
|
# getting updates should not be rate limited!
|
|
|
|
if endpoint == "getUpdates" or not self.rate_limiter:
|
|
|
|
return await super()._do_post(
|
|
|
|
endpoint=endpoint,
|
|
|
|
data=data,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
)
|
|
|
|
|
|
|
|
kwargs = {
|
|
|
|
"read_timeout": read_timeout,
|
|
|
|
"write_timeout": write_timeout,
|
|
|
|
"connect_timeout": connect_timeout,
|
|
|
|
"pool_timeout": pool_timeout,
|
|
|
|
}
|
|
|
|
self._logger.debug(
|
|
|
|
"Passing request through rate limiter of type %s with rate_limit_args %s",
|
|
|
|
type(self.rate_limiter),
|
|
|
|
rate_limit_args,
|
|
|
|
)
|
|
|
|
return await self.rate_limiter.process_request(
|
|
|
|
callback=super()._do_post,
|
|
|
|
args=(endpoint, data),
|
|
|
|
kwargs=kwargs,
|
|
|
|
endpoint=endpoint,
|
|
|
|
data=data,
|
|
|
|
rate_limit_args=rate_limit_args,
|
|
|
|
)
|
|
|
|
|
2021-10-03 15:10:13 +02:00
|
|
|
@property
|
|
|
|
def defaults(self) -> Optional["Defaults"]:
|
|
|
|
"""The :class:`telegram.ext.Defaults` used by this bot, if any."""
|
|
|
|
# This is a property because defaults shouldn't be changed at runtime
|
|
|
|
return self._defaults
|
|
|
|
|
2022-08-26 06:50:03 +02:00
|
|
|
@property
|
|
|
|
def rate_limiter(self) -> Optional["BaseRateLimiter"]:
|
|
|
|
"""The :class:`telegram.ext.BaseRateLimiter` used by this bot, if any.
|
|
|
|
|
|
|
|
.. versionadded:: 20.0
|
|
|
|
"""
|
|
|
|
# This is a property because the rate limiter shouldn't be changed at runtime
|
|
|
|
return self._rate_limiter
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
def _insert_defaults(self, data: Dict[str, object]) -> None:
|
2021-10-03 15:10:13 +02:00
|
|
|
"""Inserts the defaults values for optional kwargs for which tg.ext.Defaults provides
|
|
|
|
convenience functionality, i.e. the kwargs with a tg.utils.helpers.DefaultValue default
|
|
|
|
|
|
|
|
data is edited in-place. As timeout is not passed via the kwargs, it needs to be passed
|
|
|
|
separately and gets returned.
|
|
|
|
|
|
|
|
This can only work, if all kwargs that may have defaults are passed in data!
|
|
|
|
"""
|
|
|
|
# if we have Defaults, we
|
|
|
|
# 1) replace all DefaultValue instances with the relevant Defaults value. If there is none,
|
|
|
|
# we fall back to the default value of the bot method
|
|
|
|
# 2) convert all datetime.datetime objects to timestamps wrt the correct default timezone
|
|
|
|
# 3) set the correct parse_mode for all InputMedia objects
|
|
|
|
for key, val in data.items():
|
|
|
|
# 1)
|
|
|
|
if isinstance(val, DefaultValue):
|
|
|
|
data[key] = (
|
|
|
|
self.defaults.api_defaults.get(key, val.value)
|
|
|
|
if self.defaults
|
|
|
|
else DefaultValue.get_value(val)
|
|
|
|
)
|
|
|
|
|
|
|
|
# 2)
|
|
|
|
elif isinstance(val, datetime):
|
|
|
|
data[key] = to_timestamp(
|
|
|
|
val, tzinfo=self.defaults.tzinfo if self.defaults else None
|
|
|
|
)
|
|
|
|
|
|
|
|
# 3)
|
2021-10-15 18:03:56 +02:00
|
|
|
elif isinstance(val, InputMedia) and val.parse_mode is DEFAULT_NONE:
|
2022-10-31 09:46:56 +01:00
|
|
|
# Copy object as not to edit it in-place
|
|
|
|
val = copy(val)
|
2021-10-15 18:03:56 +02:00
|
|
|
val.parse_mode = self.defaults.parse_mode if self.defaults else None
|
2022-10-31 09:46:56 +01:00
|
|
|
data[key] = val
|
2021-10-03 15:10:13 +02:00
|
|
|
elif key == "media" and isinstance(val, list):
|
2022-10-31 09:46:56 +01:00
|
|
|
# Copy objects as not to edit them in-place
|
|
|
|
copy_list = [copy(media) for media in val]
|
|
|
|
for media in copy_list:
|
2021-10-03 15:10:13 +02:00
|
|
|
if media.parse_mode is DEFAULT_NONE:
|
|
|
|
media.parse_mode = self.defaults.parse_mode if self.defaults else None
|
2022-10-31 09:46:56 +01:00
|
|
|
data[key] = copy_list
|
2021-10-03 15:10:13 +02:00
|
|
|
|
2021-06-06 11:48:48 +02:00
|
|
|
def _replace_keyboard(self, reply_markup: Optional[ReplyMarkup]) -> Optional[ReplyMarkup]:
|
|
|
|
# If the reply_markup is an inline keyboard and we allow arbitrary callback data, let the
|
|
|
|
# CallbackDataCache build a new keyboard with the data replaced. Otherwise return the input
|
2022-10-07 10:18:08 +02:00
|
|
|
if isinstance(reply_markup, InlineKeyboardMarkup) and self.callback_data_cache is not None:
|
2021-06-06 11:48:48 +02:00
|
|
|
return self.callback_data_cache.process_keyboard(reply_markup)
|
|
|
|
|
|
|
|
return reply_markup
|
|
|
|
|
|
|
|
def insert_callback_data(self, update: Update) -> None:
|
|
|
|
"""If this bot allows for arbitrary callback data, this inserts the cached data into all
|
|
|
|
corresponding buttons within this update.
|
|
|
|
|
|
|
|
Note:
|
2022-04-24 12:38:09 +02:00
|
|
|
Checks :attr:`telegram.Message.via_bot` and :attr:`telegram.Message.from_user`
|
|
|
|
to figure out if a) a reply markup exists and b) it was actually sent by this
|
|
|
|
bot. If not, the message will be returned unchanged.
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
Note that this will fail for channel posts, as :attr:`telegram.Message.from_user` is
|
2022-04-24 12:38:09 +02:00
|
|
|
:obj:`None` for those! In the corresponding reply markups, the callback data will be
|
2021-06-06 11:48:48 +02:00
|
|
|
replaced by :class:`telegram.ext.InvalidCallbackData`.
|
|
|
|
|
|
|
|
Warning:
|
|
|
|
*In place*, i.e. the passed :class:`telegram.Message` will be changed!
|
|
|
|
|
|
|
|
Args:
|
2022-02-09 17:30:16 +01:00
|
|
|
update (:class:`telegram.Update`): The update.
|
2021-06-06 11:48:48 +02:00
|
|
|
|
|
|
|
"""
|
|
|
|
# The only incoming updates that can directly contain a message sent by the bot itself are:
|
|
|
|
# * CallbackQueries
|
|
|
|
# * Messages where the pinned_message is sent by the bot
|
|
|
|
# * Messages where the reply_to_message is sent by the bot
|
|
|
|
# * Messages where via_bot is the bot
|
|
|
|
# Finally there is effective_chat.pinned message, but that's only returned in get_chat
|
|
|
|
if update.callback_query:
|
|
|
|
self._insert_callback_data(update.callback_query)
|
|
|
|
# elif instead of if, as effective_message includes callback_query.message
|
|
|
|
# and that has already been processed
|
|
|
|
elif update.effective_message:
|
|
|
|
self._insert_callback_data(update.effective_message)
|
|
|
|
|
|
|
|
def _insert_callback_data(self, obj: HandledTypes) -> HandledTypes:
|
2022-10-07 10:18:08 +02:00
|
|
|
if self.callback_data_cache is None:
|
2021-06-06 11:48:48 +02:00
|
|
|
return obj
|
|
|
|
|
|
|
|
if isinstance(obj, CallbackQuery):
|
|
|
|
self.callback_data_cache.process_callback_query(obj)
|
|
|
|
return obj # type: ignore[return-value]
|
|
|
|
|
|
|
|
if isinstance(obj, Message):
|
|
|
|
if obj.reply_to_message:
|
|
|
|
# reply_to_message can't contain further reply_to_messages, so no need to check
|
|
|
|
self.callback_data_cache.process_message(obj.reply_to_message)
|
|
|
|
if obj.reply_to_message.pinned_message:
|
|
|
|
# pinned messages can't contain reply_to_message, no need to check
|
|
|
|
self.callback_data_cache.process_message(obj.reply_to_message.pinned_message)
|
|
|
|
if obj.pinned_message:
|
|
|
|
# pinned messages can't contain reply_to_message, no need to check
|
|
|
|
self.callback_data_cache.process_message(obj.pinned_message)
|
|
|
|
|
|
|
|
# Finally, handle the message itself
|
|
|
|
self.callback_data_cache.process_message(message=obj)
|
|
|
|
return obj # type: ignore[return-value]
|
|
|
|
|
|
|
|
if isinstance(obj, Chat) and obj.pinned_message:
|
|
|
|
self.callback_data_cache.process_message(obj.pinned_message)
|
|
|
|
|
|
|
|
return obj
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
async def _send_message(
|
2021-06-06 11:48:48 +02:00
|
|
|
self,
|
|
|
|
endpoint: str,
|
|
|
|
data: JSONDict,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
disable_notification: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
2022-05-18 17:18:44 +02:00
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
) -> Union[bool, Message]:
|
|
|
|
# We override this method to call self._replace_keyboard and self._insert_callback_data.
|
|
|
|
# This covers most methods that have a reply_markup
|
2022-04-24 12:38:09 +02:00
|
|
|
result = await super()._send_message(
|
2021-06-06 11:48:48 +02:00
|
|
|
endpoint=endpoint,
|
|
|
|
data=data,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_markup=self._replace_keyboard(reply_markup),
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
2022-05-18 17:18:44 +02:00
|
|
|
protect_content=protect_content,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs=api_kwargs,
|
|
|
|
)
|
|
|
|
if isinstance(result, Message):
|
|
|
|
self._insert_callback_data(result)
|
|
|
|
return result
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
async def get_updates(
|
2021-06-06 11:48:48 +02:00
|
|
|
self,
|
|
|
|
offset: int = None,
|
2022-05-09 19:30:46 +02:00
|
|
|
limit: int = None,
|
|
|
|
timeout: float = None,
|
2022-05-18 17:18:44 +02:00
|
|
|
allowed_updates: List[str] = None,
|
|
|
|
*,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout: float = 2,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
) -> List[Update]:
|
2022-04-24 12:38:09 +02:00
|
|
|
updates = await super().get_updates(
|
2021-06-06 11:48:48 +02:00
|
|
|
offset=offset,
|
|
|
|
limit=limit,
|
|
|
|
timeout=timeout,
|
2022-05-18 17:18:44 +02:00
|
|
|
allowed_updates=allowed_updates,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs=api_kwargs,
|
|
|
|
)
|
|
|
|
|
|
|
|
for update in updates:
|
|
|
|
self.insert_callback_data(update)
|
|
|
|
|
|
|
|
return updates
|
|
|
|
|
2022-05-05 09:27:54 +02:00
|
|
|
def _effective_inline_results(
|
2021-06-06 11:48:48 +02:00
|
|
|
self,
|
|
|
|
results: Union[
|
|
|
|
Sequence["InlineQueryResult"], Callable[[int], Optional[Sequence["InlineQueryResult"]]]
|
|
|
|
],
|
|
|
|
next_offset: str = None,
|
|
|
|
current_offset: str = None,
|
|
|
|
) -> Tuple[Sequence["InlineQueryResult"], Optional[str]]:
|
2021-10-03 15:10:13 +02:00
|
|
|
"""This method is called by Bot.answer_inline_query to build the actual results list.
|
2021-06-06 11:48:48 +02:00
|
|
|
Overriding this to call self._replace_keyboard suffices
|
|
|
|
"""
|
|
|
|
effective_results, next_offset = super()._effective_inline_results(
|
|
|
|
results=results, next_offset=next_offset, current_offset=current_offset
|
|
|
|
)
|
|
|
|
|
|
|
|
# Process arbitrary callback
|
2022-10-07 10:18:08 +02:00
|
|
|
if self.callback_data_cache is None:
|
2021-06-06 11:48:48 +02:00
|
|
|
return effective_results, next_offset
|
|
|
|
results = []
|
|
|
|
for result in effective_results:
|
|
|
|
# All currently existingInlineQueryResults have a reply_markup, but future ones
|
|
|
|
# might not have. Better be save than sorry
|
|
|
|
if not hasattr(result, "reply_markup"):
|
|
|
|
results.append(result)
|
|
|
|
else:
|
|
|
|
# We build a new result in case the user wants to use the same object in
|
|
|
|
# different places
|
|
|
|
new_result = copy(result)
|
|
|
|
markup = self._replace_keyboard(result.reply_markup) # type: ignore[attr-defined]
|
2021-08-19 22:01:10 +02:00
|
|
|
new_result.reply_markup = markup # type: ignore[attr-defined]
|
2021-06-06 11:48:48 +02:00
|
|
|
results.append(new_result)
|
|
|
|
|
|
|
|
return results, next_offset
|
|
|
|
|
2021-10-03 15:10:13 +02:00
|
|
|
@no_type_check # mypy doesn't play too well with hasattr
|
2022-10-31 09:46:56 +01:00
|
|
|
def _insert_defaults_for_ilq_results(self, res: "InlineQueryResult") -> "InlineQueryResult":
|
2021-10-03 15:10:13 +02:00
|
|
|
"""This method is called by Bot.answer_inline_query to replace `DefaultValue(obj)` with
|
|
|
|
`obj`.
|
|
|
|
Overriding this to call insert the actual desired default values.
|
|
|
|
"""
|
2022-10-31 09:46:56 +01:00
|
|
|
# Copy the objects that need modification to avoid modifying the original object
|
|
|
|
copied = False
|
2021-10-03 15:10:13 +02:00
|
|
|
if hasattr(res, "parse_mode") and res.parse_mode is DEFAULT_NONE:
|
2022-10-31 09:46:56 +01:00
|
|
|
res = copy(res)
|
|
|
|
copied = True
|
2021-10-03 15:10:13 +02:00
|
|
|
res.parse_mode = self.defaults.parse_mode if self.defaults else None
|
|
|
|
if hasattr(res, "input_message_content") and res.input_message_content:
|
|
|
|
if (
|
|
|
|
hasattr(res.input_message_content, "parse_mode")
|
|
|
|
and res.input_message_content.parse_mode is DEFAULT_NONE
|
|
|
|
):
|
2022-10-31 09:46:56 +01:00
|
|
|
if not copied:
|
|
|
|
res = copy(res)
|
|
|
|
copied = True
|
2021-10-03 15:10:13 +02:00
|
|
|
res.input_message_content.parse_mode = (
|
|
|
|
self.defaults.parse_mode if self.defaults else None
|
|
|
|
)
|
|
|
|
if (
|
|
|
|
hasattr(res.input_message_content, "disable_web_page_preview")
|
|
|
|
and res.input_message_content.disable_web_page_preview is DEFAULT_NONE
|
|
|
|
):
|
2022-10-31 09:46:56 +01:00
|
|
|
if not copied:
|
|
|
|
res = copy(res)
|
2021-10-03 15:10:13 +02:00
|
|
|
res.input_message_content.disable_web_page_preview = (
|
|
|
|
self.defaults.disable_web_page_preview if self.defaults else None
|
|
|
|
)
|
|
|
|
|
2022-10-31 09:46:56 +01:00
|
|
|
return res
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
async def stop_poll(
|
2021-06-06 11:48:48 +02:00
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
message_id: int,
|
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
2022-05-18 17:18:44 +02:00
|
|
|
*,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs: JSONDict = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
rate_limit_args: RLARGS = None,
|
2021-06-06 11:48:48 +02:00
|
|
|
) -> Poll:
|
|
|
|
# We override this method to call self._replace_keyboard
|
2022-04-24 12:38:09 +02:00
|
|
|
return await super().stop_poll(
|
2021-06-06 11:48:48 +02:00
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
reply_markup=self._replace_keyboard(reply_markup),
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
2022-08-26 06:50:03 +02:00
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
2021-06-06 11:48:48 +02:00
|
|
|
)
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
async def copy_message(
|
2021-06-06 11:48:48 +02:00
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
from_chat_id: Union[str, int],
|
|
|
|
message_id: int,
|
|
|
|
caption: str = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[Tuple["MessageEntity", ...], List["MessageEntity"]] = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
allow_sending_without_reply: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
2022-05-18 17:18:44 +02:00
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs: JSONDict = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
rate_limit_args: RLARGS = None,
|
2021-06-06 11:48:48 +02:00
|
|
|
) -> MessageId:
|
|
|
|
# We override this method to call self._replace_keyboard
|
2022-04-24 12:38:09 +02:00
|
|
|
return await super().copy_message(
|
2021-06-06 11:48:48 +02:00
|
|
|
chat_id=chat_id,
|
|
|
|
from_chat_id=from_chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
caption=caption,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
reply_markup=self._replace_keyboard(reply_markup),
|
2022-05-18 17:18:44 +02:00
|
|
|
protect_content=protect_content,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
2022-08-26 06:50:03 +02:00
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
2021-06-06 11:48:48 +02:00
|
|
|
)
|
|
|
|
|
2022-04-24 12:38:09 +02:00
|
|
|
async def get_chat(
|
2021-06-06 11:48:48 +02:00
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
2022-05-18 17:18:44 +02:00
|
|
|
*,
|
2022-04-24 12:38:09 +02:00
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
2021-06-06 11:48:48 +02:00
|
|
|
api_kwargs: JSONDict = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
rate_limit_args: RLARGS = None,
|
2021-06-06 11:48:48 +02:00
|
|
|
) -> Chat:
|
|
|
|
# We override this method to call self._insert_callback_data
|
2022-04-24 12:38:09 +02:00
|
|
|
result = await super().get_chat(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
2022-08-26 06:50:03 +02:00
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
2022-04-24 12:38:09 +02:00
|
|
|
)
|
2021-06-06 11:48:48 +02:00
|
|
|
return self._insert_callback_data(result)
|
2021-09-15 17:07:11 +02:00
|
|
|
|
2022-08-26 06:50:03 +02:00
|
|
|
async def add_sticker_to_set(
|
|
|
|
self,
|
|
|
|
user_id: Union[str, int],
|
|
|
|
name: str,
|
|
|
|
emojis: str,
|
|
|
|
png_sticker: FileInput = None,
|
|
|
|
mask_position: MaskPosition = None,
|
|
|
|
tgs_sticker: FileInput = None,
|
|
|
|
webm_sticker: FileInput = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().add_sticker_to_set(
|
|
|
|
user_id=user_id,
|
|
|
|
name=name,
|
|
|
|
emojis=emojis,
|
|
|
|
png_sticker=png_sticker,
|
|
|
|
mask_position=mask_position,
|
|
|
|
tgs_sticker=tgs_sticker,
|
|
|
|
webm_sticker=webm_sticker,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def answer_callback_query(
|
|
|
|
self,
|
|
|
|
callback_query_id: str,
|
|
|
|
text: str = None,
|
|
|
|
show_alert: bool = None,
|
|
|
|
url: str = None,
|
|
|
|
cache_time: int = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().answer_callback_query(
|
|
|
|
callback_query_id=callback_query_id,
|
|
|
|
text=text,
|
|
|
|
show_alert=show_alert,
|
|
|
|
url=url,
|
|
|
|
cache_time=cache_time,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def answer_inline_query(
|
|
|
|
self,
|
|
|
|
inline_query_id: str,
|
|
|
|
results: Union[
|
|
|
|
Sequence["InlineQueryResult"], Callable[[int], Optional[Sequence["InlineQueryResult"]]]
|
|
|
|
],
|
|
|
|
cache_time: int = None,
|
|
|
|
is_personal: bool = None,
|
|
|
|
next_offset: str = None,
|
|
|
|
switch_pm_text: str = None,
|
|
|
|
switch_pm_parameter: str = None,
|
|
|
|
*,
|
|
|
|
current_offset: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().answer_inline_query(
|
|
|
|
inline_query_id=inline_query_id,
|
|
|
|
results=results,
|
|
|
|
cache_time=cache_time,
|
|
|
|
is_personal=is_personal,
|
|
|
|
next_offset=next_offset,
|
|
|
|
switch_pm_text=switch_pm_text,
|
|
|
|
switch_pm_parameter=switch_pm_parameter,
|
|
|
|
current_offset=current_offset,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def answer_pre_checkout_query(
|
|
|
|
self,
|
|
|
|
pre_checkout_query_id: str,
|
|
|
|
ok: bool,
|
|
|
|
error_message: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().answer_pre_checkout_query(
|
|
|
|
pre_checkout_query_id=pre_checkout_query_id,
|
|
|
|
ok=ok,
|
|
|
|
error_message=error_message,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def answer_shipping_query(
|
|
|
|
self,
|
|
|
|
shipping_query_id: str,
|
|
|
|
ok: bool,
|
|
|
|
shipping_options: List[ShippingOption] = None,
|
|
|
|
error_message: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().answer_shipping_query(
|
|
|
|
shipping_query_id=shipping_query_id,
|
|
|
|
ok=ok,
|
|
|
|
shipping_options=shipping_options,
|
|
|
|
error_message=error_message,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def answer_web_app_query(
|
|
|
|
self,
|
|
|
|
web_app_query_id: str,
|
|
|
|
result: "InlineQueryResult",
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> SentWebAppMessage:
|
|
|
|
return await super().answer_web_app_query(
|
|
|
|
web_app_query_id=web_app_query_id,
|
|
|
|
result=result,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def approve_chat_join_request(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: int,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().approve_chat_join_request(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def ban_chat_member(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: Union[str, int],
|
|
|
|
until_date: Union[int, datetime] = None,
|
|
|
|
revoke_messages: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().ban_chat_member(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
until_date=until_date,
|
|
|
|
revoke_messages=revoke_messages,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def ban_chat_sender_chat(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
sender_chat_id: int,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().ban_chat_sender_chat(
|
|
|
|
chat_id=chat_id,
|
|
|
|
sender_chat_id=sender_chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def create_chat_invite_link(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
expire_date: Union[int, datetime] = None,
|
|
|
|
member_limit: int = None,
|
|
|
|
name: str = None,
|
|
|
|
creates_join_request: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> ChatInviteLink:
|
|
|
|
return await super().create_chat_invite_link(
|
|
|
|
chat_id=chat_id,
|
|
|
|
expire_date=expire_date,
|
|
|
|
member_limit=member_limit,
|
|
|
|
name=name,
|
|
|
|
creates_join_request=creates_join_request,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def create_invoice_link(
|
|
|
|
self,
|
|
|
|
title: str,
|
|
|
|
description: str,
|
|
|
|
payload: str,
|
|
|
|
provider_token: str,
|
|
|
|
currency: str,
|
|
|
|
prices: List["LabeledPrice"],
|
|
|
|
max_tip_amount: int = None,
|
|
|
|
suggested_tip_amounts: List[int] = None,
|
|
|
|
provider_data: Union[str, object] = None,
|
|
|
|
photo_url: str = None,
|
|
|
|
photo_size: int = None,
|
|
|
|
photo_width: int = None,
|
|
|
|
photo_height: int = None,
|
|
|
|
need_name: bool = None,
|
|
|
|
need_phone_number: bool = None,
|
|
|
|
need_email: bool = None,
|
|
|
|
need_shipping_address: bool = None,
|
|
|
|
send_phone_number_to_provider: bool = None,
|
|
|
|
send_email_to_provider: bool = None,
|
|
|
|
is_flexible: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> str:
|
|
|
|
return await super().create_invoice_link(
|
|
|
|
title=title,
|
|
|
|
description=description,
|
|
|
|
payload=payload,
|
|
|
|
provider_token=provider_token,
|
|
|
|
currency=currency,
|
|
|
|
prices=prices,
|
|
|
|
max_tip_amount=max_tip_amount,
|
|
|
|
suggested_tip_amounts=suggested_tip_amounts,
|
|
|
|
provider_data=provider_data,
|
|
|
|
photo_url=photo_url,
|
|
|
|
photo_size=photo_size,
|
|
|
|
photo_width=photo_width,
|
|
|
|
photo_height=photo_height,
|
|
|
|
need_name=need_name,
|
|
|
|
need_phone_number=need_phone_number,
|
|
|
|
need_email=need_email,
|
|
|
|
need_shipping_address=need_shipping_address,
|
|
|
|
send_phone_number_to_provider=send_phone_number_to_provider,
|
|
|
|
send_email_to_provider=send_email_to_provider,
|
|
|
|
is_flexible=is_flexible,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def create_new_sticker_set(
|
|
|
|
self,
|
|
|
|
user_id: Union[str, int],
|
|
|
|
name: str,
|
|
|
|
title: str,
|
|
|
|
emojis: str,
|
|
|
|
png_sticker: FileInput = None,
|
|
|
|
mask_position: MaskPosition = None,
|
|
|
|
tgs_sticker: FileInput = None,
|
|
|
|
webm_sticker: FileInput = None,
|
|
|
|
sticker_type: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().create_new_sticker_set(
|
|
|
|
user_id=user_id,
|
|
|
|
name=name,
|
|
|
|
title=title,
|
|
|
|
emojis=emojis,
|
|
|
|
png_sticker=png_sticker,
|
|
|
|
mask_position=mask_position,
|
|
|
|
tgs_sticker=tgs_sticker,
|
|
|
|
webm_sticker=webm_sticker,
|
|
|
|
sticker_type=sticker_type,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def decline_chat_join_request(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: int,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().decline_chat_join_request(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def delete_chat_photo(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().delete_chat_photo(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def delete_chat_sticker_set(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().delete_chat_sticker_set(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def delete_message(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
message_id: int,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().delete_message(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def delete_my_commands(
|
|
|
|
self,
|
|
|
|
scope: BotCommandScope = None,
|
|
|
|
language_code: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().delete_my_commands(
|
|
|
|
scope=scope,
|
|
|
|
language_code=language_code,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def delete_sticker_from_set(
|
|
|
|
self,
|
|
|
|
sticker: str,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().delete_sticker_from_set(
|
|
|
|
sticker=sticker,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def delete_webhook(
|
|
|
|
self,
|
|
|
|
drop_pending_updates: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().delete_webhook(
|
|
|
|
drop_pending_updates=drop_pending_updates,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def edit_chat_invite_link(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
invite_link: Union[str, "ChatInviteLink"],
|
|
|
|
expire_date: Union[int, datetime] = None,
|
|
|
|
member_limit: int = None,
|
|
|
|
name: str = None,
|
|
|
|
creates_join_request: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> ChatInviteLink:
|
|
|
|
return await super().edit_chat_invite_link(
|
|
|
|
chat_id=chat_id,
|
|
|
|
invite_link=invite_link,
|
|
|
|
expire_date=expire_date,
|
|
|
|
member_limit=member_limit,
|
|
|
|
name=name,
|
|
|
|
creates_join_request=creates_join_request,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def edit_message_caption(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
|
|
|
inline_message_id: str = None,
|
|
|
|
caption: str = None,
|
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().edit_message_caption(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
caption=caption,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def edit_message_live_location(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
latitude: float = None,
|
|
|
|
longitude: float = None,
|
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
horizontal_accuracy: float = None,
|
|
|
|
heading: int = None,
|
|
|
|
proximity_alert_radius: int = None,
|
|
|
|
*,
|
|
|
|
location: Location = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().edit_message_live_location(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
latitude=latitude,
|
|
|
|
longitude=longitude,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
horizontal_accuracy=horizontal_accuracy,
|
|
|
|
heading=heading,
|
|
|
|
proximity_alert_radius=proximity_alert_radius,
|
|
|
|
location=location,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def edit_message_media(
|
|
|
|
self,
|
|
|
|
media: "InputMedia",
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().edit_message_media(
|
|
|
|
media=media,
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def edit_message_reply_markup(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
reply_markup: Optional["InlineKeyboardMarkup"] = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().edit_message_reply_markup(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def edit_message_text(
|
|
|
|
self,
|
|
|
|
text: str,
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
disable_web_page_preview: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().edit_message_text(
|
|
|
|
text=text,
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
disable_web_page_preview=disable_web_page_preview,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
entities=entities,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def export_chat_invite_link(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> str:
|
|
|
|
return await super().export_chat_invite_link(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def forward_message(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
from_chat_id: Union[str, int],
|
|
|
|
message_id: int,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().forward_message(
|
|
|
|
chat_id=chat_id,
|
|
|
|
from_chat_id=from_chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_chat_administrators(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> List[ChatMember]:
|
|
|
|
return await super().get_chat_administrators(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_chat_member(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> ChatMember:
|
|
|
|
return await super().get_chat_member(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_chat_member_count(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> int:
|
|
|
|
return await super().get_chat_member_count(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_chat_menu_button(
|
|
|
|
self,
|
|
|
|
chat_id: int = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> MenuButton:
|
|
|
|
return await super().get_chat_menu_button(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_file(
|
|
|
|
self,
|
|
|
|
file_id: Union[
|
|
|
|
str, Animation, Audio, ChatPhoto, Document, PhotoSize, Sticker, Video, VideoNote, Voice
|
|
|
|
],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> File:
|
|
|
|
return await super().get_file(
|
|
|
|
file_id=file_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_game_high_scores(
|
|
|
|
self,
|
|
|
|
user_id: Union[int, str],
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> List[GameHighScore]:
|
|
|
|
return await super().get_game_high_scores(
|
|
|
|
user_id=user_id,
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_me(
|
|
|
|
self,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> User:
|
|
|
|
return await super().get_me(
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_my_commands(
|
|
|
|
self,
|
|
|
|
scope: BotCommandScope = None,
|
|
|
|
language_code: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> List[BotCommand]:
|
|
|
|
return await super().get_my_commands(
|
|
|
|
scope=scope,
|
|
|
|
language_code=language_code,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_my_default_administrator_rights(
|
|
|
|
self,
|
|
|
|
for_channels: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> ChatAdministratorRights:
|
|
|
|
return await super().get_my_default_administrator_rights(
|
|
|
|
for_channels=for_channels,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_sticker_set(
|
|
|
|
self,
|
|
|
|
name: str,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> StickerSet:
|
|
|
|
return await super().get_sticker_set(
|
|
|
|
name=name,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_custom_emoji_stickers(
|
|
|
|
self,
|
|
|
|
custom_emoji_ids: List[str],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> List[Sticker]:
|
|
|
|
return await super().get_custom_emoji_stickers(
|
|
|
|
custom_emoji_ids=custom_emoji_ids,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_user_profile_photos(
|
|
|
|
self,
|
|
|
|
user_id: Union[str, int],
|
|
|
|
offset: int = None,
|
|
|
|
limit: int = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> UserProfilePhotos:
|
|
|
|
return await super().get_user_profile_photos(
|
|
|
|
user_id=user_id,
|
|
|
|
offset=offset,
|
|
|
|
limit=limit,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def get_webhook_info(
|
|
|
|
self,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> WebhookInfo:
|
|
|
|
return await super().get_webhook_info(
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def leave_chat(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().leave_chat(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def log_out(
|
|
|
|
self,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().log_out(
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def close(
|
|
|
|
self,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().close(
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def pin_chat_message(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
message_id: int,
|
|
|
|
disable_notification: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().pin_chat_message(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def promote_chat_member(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: Union[str, int],
|
|
|
|
can_change_info: bool = None,
|
|
|
|
can_post_messages: bool = None,
|
|
|
|
can_edit_messages: bool = None,
|
|
|
|
can_delete_messages: bool = None,
|
|
|
|
can_invite_users: bool = None,
|
|
|
|
can_restrict_members: bool = None,
|
|
|
|
can_pin_messages: bool = None,
|
|
|
|
can_promote_members: bool = None,
|
|
|
|
is_anonymous: bool = None,
|
|
|
|
can_manage_chat: bool = None,
|
|
|
|
can_manage_video_chats: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().promote_chat_member(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
can_change_info=can_change_info,
|
|
|
|
can_post_messages=can_post_messages,
|
|
|
|
can_edit_messages=can_edit_messages,
|
|
|
|
can_delete_messages=can_delete_messages,
|
|
|
|
can_invite_users=can_invite_users,
|
|
|
|
can_restrict_members=can_restrict_members,
|
|
|
|
can_pin_messages=can_pin_messages,
|
|
|
|
can_promote_members=can_promote_members,
|
|
|
|
is_anonymous=is_anonymous,
|
|
|
|
can_manage_chat=can_manage_chat,
|
|
|
|
can_manage_video_chats=can_manage_video_chats,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def restrict_chat_member(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: Union[str, int],
|
|
|
|
permissions: ChatPermissions,
|
|
|
|
until_date: Union[int, datetime] = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().restrict_chat_member(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
permissions=permissions,
|
|
|
|
until_date=until_date,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def revoke_chat_invite_link(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
invite_link: Union[str, "ChatInviteLink"],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> ChatInviteLink:
|
|
|
|
return await super().revoke_chat_invite_link(
|
|
|
|
chat_id=chat_id,
|
|
|
|
invite_link=invite_link,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_animation(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
animation: Union[FileInput, "Animation"],
|
|
|
|
duration: int = None,
|
|
|
|
width: int = None,
|
|
|
|
height: int = None,
|
|
|
|
thumb: FileInput = None,
|
|
|
|
caption: str = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_animation(
|
|
|
|
chat_id=chat_id,
|
|
|
|
animation=animation,
|
|
|
|
duration=duration,
|
|
|
|
width=width,
|
|
|
|
height=height,
|
|
|
|
thumb=thumb,
|
|
|
|
caption=caption,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_audio(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
audio: Union[FileInput, "Audio"],
|
|
|
|
duration: int = None,
|
|
|
|
performer: str = None,
|
|
|
|
title: str = None,
|
|
|
|
caption: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
thumb: FileInput = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_audio(
|
|
|
|
chat_id=chat_id,
|
|
|
|
audio=audio,
|
|
|
|
duration=duration,
|
|
|
|
performer=performer,
|
|
|
|
title=title,
|
|
|
|
caption=caption,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
thumb=thumb,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_chat_action(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
action: str,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().send_chat_action(
|
|
|
|
chat_id=chat_id,
|
|
|
|
action=action,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_contact(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
phone_number: str = None,
|
|
|
|
first_name: str = None,
|
|
|
|
last_name: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
vcard: str = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
contact: Contact = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_contact(
|
|
|
|
chat_id=chat_id,
|
|
|
|
phone_number=phone_number,
|
|
|
|
first_name=first_name,
|
|
|
|
last_name=last_name,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
vcard=vcard,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
contact=contact,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_dice(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
disable_notification: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
emoji: str = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_dice(
|
|
|
|
chat_id=chat_id,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
emoji=emoji,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_document(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
document: Union[FileInput, "Document"],
|
|
|
|
caption: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
thumb: FileInput = None,
|
|
|
|
disable_content_type_detection: bool = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_document(
|
|
|
|
chat_id=chat_id,
|
|
|
|
document=document,
|
|
|
|
caption=caption,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
thumb=thumb,
|
|
|
|
disable_content_type_detection=disable_content_type_detection,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_game(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
game_short_name: str,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_game(
|
|
|
|
chat_id=chat_id,
|
|
|
|
game_short_name=game_short_name,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_invoice(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
title: str,
|
|
|
|
description: str,
|
|
|
|
payload: str,
|
|
|
|
provider_token: str,
|
|
|
|
currency: str,
|
|
|
|
prices: List["LabeledPrice"],
|
|
|
|
start_parameter: str = None,
|
|
|
|
photo_url: str = None,
|
|
|
|
photo_size: int = None,
|
|
|
|
photo_width: int = None,
|
|
|
|
photo_height: int = None,
|
|
|
|
need_name: bool = None,
|
|
|
|
need_phone_number: bool = None,
|
|
|
|
need_email: bool = None,
|
|
|
|
need_shipping_address: bool = None,
|
|
|
|
is_flexible: bool = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
provider_data: Union[str, object] = None,
|
|
|
|
send_phone_number_to_provider: bool = None,
|
|
|
|
send_email_to_provider: bool = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
max_tip_amount: int = None,
|
|
|
|
suggested_tip_amounts: List[int] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_invoice(
|
|
|
|
chat_id=chat_id,
|
|
|
|
title=title,
|
|
|
|
description=description,
|
|
|
|
payload=payload,
|
|
|
|
provider_token=provider_token,
|
|
|
|
currency=currency,
|
|
|
|
prices=prices,
|
|
|
|
start_parameter=start_parameter,
|
|
|
|
photo_url=photo_url,
|
|
|
|
photo_size=photo_size,
|
|
|
|
photo_width=photo_width,
|
|
|
|
photo_height=photo_height,
|
|
|
|
need_name=need_name,
|
|
|
|
need_phone_number=need_phone_number,
|
|
|
|
need_email=need_email,
|
|
|
|
need_shipping_address=need_shipping_address,
|
|
|
|
is_flexible=is_flexible,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
provider_data=provider_data,
|
|
|
|
send_phone_number_to_provider=send_phone_number_to_provider,
|
|
|
|
send_email_to_provider=send_email_to_provider,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
max_tip_amount=max_tip_amount,
|
|
|
|
suggested_tip_amounts=suggested_tip_amounts,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_location(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
latitude: float = None,
|
|
|
|
longitude: float = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
live_period: int = None,
|
|
|
|
horizontal_accuracy: float = None,
|
|
|
|
heading: int = None,
|
|
|
|
proximity_alert_radius: int = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
location: Location = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_location(
|
|
|
|
chat_id=chat_id,
|
|
|
|
latitude=latitude,
|
|
|
|
longitude=longitude,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
live_period=live_period,
|
|
|
|
horizontal_accuracy=horizontal_accuracy,
|
|
|
|
heading=heading,
|
|
|
|
proximity_alert_radius=proximity_alert_radius,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
location=location,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_media_group(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
media: List[
|
|
|
|
Union["InputMediaAudio", "InputMediaDocument", "InputMediaPhoto", "InputMediaVideo"]
|
|
|
|
],
|
|
|
|
disable_notification: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
2022-11-02 08:32:40 +01:00
|
|
|
caption: Optional[str] = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
) -> List[Message]:
|
|
|
|
return await super().send_media_group(
|
|
|
|
chat_id=chat_id,
|
|
|
|
media=media,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
2022-11-02 08:32:40 +01:00
|
|
|
caption=caption,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
caption_entities=caption_entities,
|
2022-08-26 06:50:03 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
async def send_message(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
text: str,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
disable_web_page_preview: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_message(
|
|
|
|
chat_id=chat_id,
|
|
|
|
text=text,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
entities=entities,
|
|
|
|
disable_web_page_preview=disable_web_page_preview,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
protect_content=protect_content,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_photo(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
photo: Union[FileInput, "PhotoSize"],
|
|
|
|
caption: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_photo(
|
|
|
|
chat_id=chat_id,
|
|
|
|
photo=photo,
|
|
|
|
caption=caption,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_poll(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
question: str,
|
|
|
|
options: List[str],
|
|
|
|
is_anonymous: bool = None,
|
|
|
|
type: str = None, # pylint: disable=redefined-builtin
|
|
|
|
allows_multiple_answers: bool = None,
|
|
|
|
correct_option_id: int = None,
|
|
|
|
is_closed: bool = None,
|
|
|
|
disable_notification: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
explanation: str = None,
|
|
|
|
explanation_parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
open_period: int = None,
|
|
|
|
close_date: Union[int, datetime] = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
explanation_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_poll(
|
|
|
|
chat_id=chat_id,
|
|
|
|
question=question,
|
|
|
|
options=options,
|
|
|
|
is_anonymous=is_anonymous,
|
|
|
|
type=type,
|
|
|
|
allows_multiple_answers=allows_multiple_answers,
|
|
|
|
correct_option_id=correct_option_id,
|
|
|
|
is_closed=is_closed,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
explanation=explanation,
|
|
|
|
explanation_parse_mode=explanation_parse_mode,
|
|
|
|
open_period=open_period,
|
|
|
|
close_date=close_date,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
explanation_entities=explanation_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_sticker(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
sticker: Union[FileInput, "Sticker"],
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_sticker(
|
|
|
|
chat_id=chat_id,
|
|
|
|
sticker=sticker,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_venue(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
latitude: float = None,
|
|
|
|
longitude: float = None,
|
|
|
|
title: str = None,
|
|
|
|
address: str = None,
|
|
|
|
foursquare_id: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
foursquare_type: str = None,
|
|
|
|
google_place_id: str = None,
|
|
|
|
google_place_type: str = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
venue: Venue = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_venue(
|
|
|
|
chat_id=chat_id,
|
|
|
|
latitude=latitude,
|
|
|
|
longitude=longitude,
|
|
|
|
title=title,
|
|
|
|
address=address,
|
|
|
|
foursquare_id=foursquare_id,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
foursquare_type=foursquare_type,
|
|
|
|
google_place_id=google_place_id,
|
|
|
|
google_place_type=google_place_type,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
venue=venue,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_video(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
video: Union[FileInput, "Video"],
|
|
|
|
duration: int = None,
|
|
|
|
caption: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
width: int = None,
|
|
|
|
height: int = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
supports_streaming: bool = None,
|
|
|
|
thumb: FileInput = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_video(
|
|
|
|
chat_id=chat_id,
|
|
|
|
video=video,
|
|
|
|
duration=duration,
|
|
|
|
caption=caption,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
width=width,
|
|
|
|
height=height,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
supports_streaming=supports_streaming,
|
|
|
|
thumb=thumb,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_video_note(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
video_note: Union[FileInput, "VideoNote"],
|
|
|
|
duration: int = None,
|
|
|
|
length: int = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
thumb: FileInput = None,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_video_note(
|
|
|
|
chat_id=chat_id,
|
|
|
|
video_note=video_note,
|
|
|
|
duration=duration,
|
|
|
|
length=length,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
thumb=thumb,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def send_voice(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
voice: Union[FileInput, "Voice"],
|
|
|
|
duration: int = None,
|
|
|
|
caption: str = None,
|
|
|
|
disable_notification: DVInput[bool] = DEFAULT_NONE,
|
|
|
|
reply_to_message_id: int = None,
|
|
|
|
reply_markup: ReplyMarkup = None,
|
|
|
|
parse_mode: ODVInput[str] = DEFAULT_NONE,
|
|
|
|
allow_sending_without_reply: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
caption_entities: Union[List["MessageEntity"], Tuple["MessageEntity", ...]] = None,
|
|
|
|
protect_content: ODVInput[bool] = DEFAULT_NONE,
|
|
|
|
*,
|
|
|
|
filename: str = None,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Message:
|
|
|
|
return await super().send_voice(
|
|
|
|
chat_id=chat_id,
|
|
|
|
voice=voice,
|
|
|
|
duration=duration,
|
|
|
|
caption=caption,
|
|
|
|
disable_notification=disable_notification,
|
|
|
|
reply_to_message_id=reply_to_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
parse_mode=parse_mode,
|
|
|
|
allow_sending_without_reply=allow_sending_without_reply,
|
|
|
|
caption_entities=caption_entities,
|
|
|
|
protect_content=protect_content,
|
|
|
|
filename=filename,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_administrator_custom_title(
|
|
|
|
self,
|
|
|
|
chat_id: Union[int, str],
|
|
|
|
user_id: Union[int, str],
|
|
|
|
custom_title: str,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_administrator_custom_title(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
custom_title=custom_title,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_description(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
description: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_description(
|
|
|
|
chat_id=chat_id,
|
|
|
|
description=description,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_menu_button(
|
|
|
|
self,
|
|
|
|
chat_id: int = None,
|
|
|
|
menu_button: MenuButton = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_menu_button(
|
|
|
|
chat_id=chat_id,
|
|
|
|
menu_button=menu_button,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_permissions(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
permissions: ChatPermissions,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_permissions(
|
|
|
|
chat_id=chat_id,
|
|
|
|
permissions=permissions,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_photo(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
photo: FileInput,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_photo(
|
|
|
|
chat_id=chat_id,
|
|
|
|
photo=photo,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_sticker_set(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
sticker_set_name: str,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_sticker_set(
|
|
|
|
chat_id=chat_id,
|
|
|
|
sticker_set_name=sticker_set_name,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_chat_title(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
title: str,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_chat_title(
|
|
|
|
chat_id=chat_id,
|
|
|
|
title=title,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_game_score(
|
|
|
|
self,
|
|
|
|
user_id: Union[int, str],
|
|
|
|
score: int,
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
force: bool = None,
|
|
|
|
disable_edit_message: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().set_game_score(
|
|
|
|
user_id=user_id,
|
|
|
|
score=score,
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
force=force,
|
|
|
|
disable_edit_message=disable_edit_message,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_my_commands(
|
|
|
|
self,
|
|
|
|
commands: List[Union[BotCommand, Tuple[str, str]]],
|
|
|
|
scope: BotCommandScope = None,
|
|
|
|
language_code: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_my_commands(
|
|
|
|
commands=commands,
|
|
|
|
scope=scope,
|
|
|
|
language_code=language_code,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_my_default_administrator_rights(
|
|
|
|
self,
|
|
|
|
rights: ChatAdministratorRights = None,
|
|
|
|
for_channels: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_my_default_administrator_rights(
|
|
|
|
rights=rights,
|
|
|
|
for_channels=for_channels,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_passport_data_errors(
|
|
|
|
self,
|
|
|
|
user_id: Union[str, int],
|
|
|
|
errors: List[PassportElementError],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_passport_data_errors(
|
|
|
|
user_id=user_id,
|
|
|
|
errors=errors,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_sticker_position_in_set(
|
|
|
|
self,
|
|
|
|
sticker: str,
|
|
|
|
position: int,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_sticker_position_in_set(
|
|
|
|
sticker=sticker,
|
|
|
|
position=position,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_sticker_set_thumb(
|
|
|
|
self,
|
|
|
|
name: str,
|
|
|
|
user_id: Union[str, int],
|
|
|
|
thumb: FileInput = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_sticker_set_thumb(
|
|
|
|
name=name,
|
|
|
|
user_id=user_id,
|
|
|
|
thumb=thumb,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def set_webhook(
|
|
|
|
self,
|
|
|
|
url: str,
|
|
|
|
certificate: FileInput = None,
|
|
|
|
max_connections: int = None,
|
|
|
|
allowed_updates: List[str] = None,
|
|
|
|
ip_address: str = None,
|
|
|
|
drop_pending_updates: bool = None,
|
|
|
|
secret_token: str = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().set_webhook(
|
|
|
|
url=url,
|
|
|
|
certificate=certificate,
|
|
|
|
max_connections=max_connections,
|
|
|
|
allowed_updates=allowed_updates,
|
|
|
|
ip_address=ip_address,
|
|
|
|
drop_pending_updates=drop_pending_updates,
|
|
|
|
secret_token=secret_token,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def stop_message_live_location(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int] = None,
|
|
|
|
message_id: int = None,
|
2022-08-27 11:58:28 +02:00
|
|
|
inline_message_id: str = None,
|
2022-08-26 06:50:03 +02:00
|
|
|
reply_markup: InlineKeyboardMarkup = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> Union[Message, bool]:
|
|
|
|
return await super().stop_message_live_location(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
inline_message_id=inline_message_id,
|
|
|
|
reply_markup=reply_markup,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def unban_chat_member(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
user_id: Union[str, int],
|
|
|
|
only_if_banned: bool = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().unban_chat_member(
|
|
|
|
chat_id=chat_id,
|
|
|
|
user_id=user_id,
|
|
|
|
only_if_banned=only_if_banned,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def unban_chat_sender_chat(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
sender_chat_id: int,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().unban_chat_sender_chat(
|
|
|
|
chat_id=chat_id,
|
|
|
|
sender_chat_id=sender_chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def unpin_all_chat_messages(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().unpin_all_chat_messages(
|
|
|
|
chat_id=chat_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def unpin_chat_message(
|
|
|
|
self,
|
|
|
|
chat_id: Union[str, int],
|
|
|
|
message_id: int = None,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> bool:
|
|
|
|
return await super().unpin_chat_message(
|
|
|
|
chat_id=chat_id,
|
|
|
|
message_id=message_id,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
async def upload_sticker_file(
|
|
|
|
self,
|
|
|
|
user_id: Union[str, int],
|
|
|
|
png_sticker: FileInput,
|
|
|
|
*,
|
|
|
|
read_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
write_timeout: ODVInput[float] = 20,
|
|
|
|
connect_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
pool_timeout: ODVInput[float] = DEFAULT_NONE,
|
|
|
|
api_kwargs: JSONDict = None,
|
|
|
|
rate_limit_args: RLARGS = None,
|
|
|
|
) -> File:
|
|
|
|
return await super().upload_sticker_file(
|
|
|
|
user_id=user_id,
|
|
|
|
png_sticker=png_sticker,
|
|
|
|
read_timeout=read_timeout,
|
|
|
|
write_timeout=write_timeout,
|
|
|
|
connect_timeout=connect_timeout,
|
|
|
|
pool_timeout=pool_timeout,
|
|
|
|
api_kwargs=self._merge_api_rl_kwargs(api_kwargs, rate_limit_args),
|
|
|
|
)
|
|
|
|
|
|
|
|
# updated camelCase aliases
|
|
|
|
getMe = get_me
|
|
|
|
sendMessage = send_message
|
|
|
|
deleteMessage = delete_message
|
|
|
|
forwardMessage = forward_message
|
|
|
|
sendPhoto = send_photo
|
|
|
|
sendAudio = send_audio
|
|
|
|
sendDocument = send_document
|
|
|
|
sendSticker = send_sticker
|
|
|
|
sendVideo = send_video
|
|
|
|
sendAnimation = send_animation
|
|
|
|
sendVoice = send_voice
|
|
|
|
sendVideoNote = send_video_note
|
|
|
|
sendMediaGroup = send_media_group
|
|
|
|
sendLocation = send_location
|
|
|
|
editMessageLiveLocation = edit_message_live_location
|
|
|
|
stopMessageLiveLocation = stop_message_live_location
|
|
|
|
sendVenue = send_venue
|
|
|
|
sendContact = send_contact
|
|
|
|
sendGame = send_game
|
|
|
|
sendChatAction = send_chat_action
|
|
|
|
answerInlineQuery = answer_inline_query
|
|
|
|
getUserProfilePhotos = get_user_profile_photos
|
|
|
|
getFile = get_file
|
|
|
|
banChatMember = ban_chat_member
|
|
|
|
banChatSenderChat = ban_chat_sender_chat
|
|
|
|
unbanChatMember = unban_chat_member
|
|
|
|
unbanChatSenderChat = unban_chat_sender_chat
|
|
|
|
answerCallbackQuery = answer_callback_query
|
|
|
|
editMessageText = edit_message_text
|
|
|
|
editMessageCaption = edit_message_caption
|
|
|
|
editMessageMedia = edit_message_media
|
|
|
|
editMessageReplyMarkup = edit_message_reply_markup
|
|
|
|
getUpdates = get_updates
|
|
|
|
setWebhook = set_webhook
|
|
|
|
deleteWebhook = delete_webhook
|
|
|
|
leaveChat = leave_chat
|
|
|
|
getChat = get_chat
|
|
|
|
getChatAdministrators = get_chat_administrators
|
|
|
|
getChatMember = get_chat_member
|
|
|
|
setChatStickerSet = set_chat_sticker_set
|
|
|
|
deleteChatStickerSet = delete_chat_sticker_set
|
|
|
|
getChatMemberCount = get_chat_member_count
|
|
|
|
getWebhookInfo = get_webhook_info
|
|
|
|
setGameScore = set_game_score
|
|
|
|
getGameHighScores = get_game_high_scores
|
|
|
|
sendInvoice = send_invoice
|
|
|
|
answerShippingQuery = answer_shipping_query
|
|
|
|
answerPreCheckoutQuery = answer_pre_checkout_query
|
|
|
|
answerWebAppQuery = answer_web_app_query
|
|
|
|
restrictChatMember = restrict_chat_member
|
|
|
|
promoteChatMember = promote_chat_member
|
|
|
|
setChatPermissions = set_chat_permissions
|
|
|
|
setChatAdministratorCustomTitle = set_chat_administrator_custom_title
|
|
|
|
exportChatInviteLink = export_chat_invite_link
|
|
|
|
createChatInviteLink = create_chat_invite_link
|
|
|
|
editChatInviteLink = edit_chat_invite_link
|
|
|
|
revokeChatInviteLink = revoke_chat_invite_link
|
|
|
|
approveChatJoinRequest = approve_chat_join_request
|
|
|
|
declineChatJoinRequest = decline_chat_join_request
|
|
|
|
setChatPhoto = set_chat_photo
|
|
|
|
deleteChatPhoto = delete_chat_photo
|
|
|
|
setChatTitle = set_chat_title
|
|
|
|
setChatDescription = set_chat_description
|
|
|
|
pinChatMessage = pin_chat_message
|
|
|
|
unpinChatMessage = unpin_chat_message
|
|
|
|
unpinAllChatMessages = unpin_all_chat_messages
|
|
|
|
getStickerSet = get_sticker_set
|
|
|
|
getCustomEmojiStickers = get_custom_emoji_stickers
|
|
|
|
uploadStickerFile = upload_sticker_file
|
|
|
|
createNewStickerSet = create_new_sticker_set
|
|
|
|
addStickerToSet = add_sticker_to_set
|
|
|
|
setStickerPositionInSet = set_sticker_position_in_set
|
|
|
|
deleteStickerFromSet = delete_sticker_from_set
|
|
|
|
setStickerSetThumb = set_sticker_set_thumb
|
|
|
|
setPassportDataErrors = set_passport_data_errors
|
|
|
|
sendPoll = send_poll
|
|
|
|
stopPoll = stop_poll
|
|
|
|
sendDice = send_dice
|
|
|
|
getMyCommands = get_my_commands
|
|
|
|
setMyCommands = set_my_commands
|
|
|
|
deleteMyCommands = delete_my_commands
|
|
|
|
logOut = log_out
|
|
|
|
copyMessage = copy_message
|
|
|
|
getChatMenuButton = get_chat_menu_button
|
|
|
|
setChatMenuButton = set_chat_menu_button
|
|
|
|
getMyDefaultAdministratorRights = get_my_default_administrator_rights
|
|
|
|
setMyDefaultAdministratorRights = set_my_default_administrator_rights
|
|
|
|
createInvoiceLink = create_invoice_link
|