2023-02-05 18:09:55 +01:00
|
|
|
#
|
|
|
|
# A library that provides a Python interface to the Telegram Bot API
|
2024-02-19 22:06:25 +03:00
|
|
|
# Copyright (C) 2015-2024
|
2023-02-05 18:09:55 +01: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/].
|
|
|
|
import inspect
|
|
|
|
|
|
|
|
keyword_args = [
|
2023-11-05 11:47:50 +01:00
|
|
|
"Keyword Arguments:",
|
2023-09-22 20:19:21 +04:00
|
|
|
(
|
2023-11-27 18:24:21 +01:00
|
|
|
" read_timeout (:obj:`float` | :obj:`None`, optional): Value to pass to "
|
2023-11-05 11:47:50 +01:00
|
|
|
" :paramref:`telegram.request.BaseRequest.post.read_timeout`. Defaults to "
|
2023-11-27 18:24:21 +01:00
|
|
|
" :attr:`~telegram.request.BaseRequest.DEFAULT_NONE`. "
|
2023-09-22 20:19:21 +04:00
|
|
|
),
|
|
|
|
(
|
2023-11-05 11:47:50 +01:00
|
|
|
" write_timeout (:obj:`float` | :obj:`None`, optional): Value to pass to "
|
|
|
|
" :paramref:`telegram.request.BaseRequest.post.write_timeout`. Defaults to "
|
2023-11-26 16:44:18 +01:00
|
|
|
" :attr:`~telegram.request.BaseRequest.DEFAULT_NONE`."
|
2023-09-22 20:19:21 +04:00
|
|
|
),
|
|
|
|
(
|
2023-11-05 11:47:50 +01:00
|
|
|
" connect_timeout (:obj:`float` | :obj:`None`, optional): Value to pass to "
|
|
|
|
" :paramref:`telegram.request.BaseRequest.post.connect_timeout`. Defaults to "
|
|
|
|
" :attr:`~telegram.request.BaseRequest.DEFAULT_NONE`."
|
2023-09-22 20:19:21 +04:00
|
|
|
),
|
|
|
|
(
|
2023-11-05 11:47:50 +01:00
|
|
|
" pool_timeout (:obj:`float` | :obj:`None`, optional): Value to pass to "
|
|
|
|
" :paramref:`telegram.request.BaseRequest.post.pool_timeout`. Defaults to "
|
|
|
|
" :attr:`~telegram.request.BaseRequest.DEFAULT_NONE`."
|
2023-09-22 20:19:21 +04:00
|
|
|
),
|
|
|
|
(
|
2023-11-05 11:47:50 +01:00
|
|
|
" api_kwargs (:obj:`dict`, optional): Arbitrary keyword arguments"
|
2024-02-07 22:35:09 +01:00
|
|
|
" to be passed to the Telegram API. See :meth:`~telegram.Bot.do_api_request` for"
|
|
|
|
" limitations."
|
2023-09-22 20:19:21 +04:00
|
|
|
),
|
2023-02-05 18:09:55 +01:00
|
|
|
"",
|
|
|
|
]
|
2023-11-26 16:44:18 +01:00
|
|
|
|
|
|
|
media_write_timeout_deprecation_methods = [
|
|
|
|
"send_photo",
|
|
|
|
"send_audio",
|
|
|
|
"send_document",
|
|
|
|
"send_sticker",
|
|
|
|
"send_video",
|
|
|
|
"send_video_note",
|
|
|
|
"send_animation",
|
|
|
|
"send_voice",
|
|
|
|
"send_media_group",
|
|
|
|
"set_chat_photo",
|
|
|
|
"upload_sticker_file",
|
|
|
|
"add_sticker_to_set",
|
|
|
|
"create_new_sticker_set",
|
|
|
|
]
|
|
|
|
media_write_timeout_deprecation = [
|
|
|
|
" write_timeout (:obj:`float` | :obj:`None`, optional): Value to pass to "
|
|
|
|
" :paramref:`telegram.request.BaseRequest.post.write_timeout`. By default, ``20`` "
|
|
|
|
" seconds are used as write timeout."
|
|
|
|
"",
|
|
|
|
"",
|
2023-11-27 19:01:57 +01:00
|
|
|
" .. deprecated:: 20.7",
|
2023-11-26 16:44:18 +01:00
|
|
|
" In future versions, the default value will be changed to "
|
|
|
|
" :attr:`~telegram.request.BaseRequest.DEFAULT_NONE`.",
|
|
|
|
"",
|
|
|
|
"",
|
|
|
|
]
|
2023-11-27 18:24:21 +01:00
|
|
|
get_updates_read_timeout_addition = [
|
|
|
|
" :paramref:`timeout` will be added to this value.",
|
|
|
|
"",
|
|
|
|
"",
|
2023-11-27 19:01:57 +01:00
|
|
|
" .. versionchanged:: 20.7",
|
2023-11-27 18:24:21 +01:00
|
|
|
" Defaults to :attr:`~telegram.request.BaseRequest.DEFAULT_NONE` instead of ",
|
|
|
|
" ``2``.",
|
2023-02-05 18:09:55 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2024-10-24 20:48:49 +02:00
|
|
|
def find_insert_pos_for_kwargs(lines: list[str]) -> int:
|
2023-02-05 18:09:55 +01:00
|
|
|
"""Finds the correct position to insert the keyword arguments and returns the index."""
|
|
|
|
for idx, value in reversed(list(enumerate(lines))): # reversed since :returns: is at the end
|
2023-11-05 11:47:50 +01:00
|
|
|
if value.startswith("Returns"):
|
2023-02-05 18:09:55 +01:00
|
|
|
return idx
|
2024-02-29 19:11:03 +01:00
|
|
|
return False
|
2023-02-05 18:09:55 +01:00
|
|
|
|
|
|
|
|
|
|
|
def check_timeout_and_api_kwargs_presence(obj: object) -> int:
|
|
|
|
"""Checks if the method has timeout and api_kwargs keyword only parameters."""
|
|
|
|
sig = inspect.signature(obj)
|
|
|
|
params_to_check = (
|
|
|
|
"read_timeout",
|
|
|
|
"write_timeout",
|
|
|
|
"connect_timeout",
|
|
|
|
"pool_timeout",
|
|
|
|
"api_kwargs",
|
|
|
|
)
|
|
|
|
return all(
|
|
|
|
param in sig.parameters and sig.parameters[param].kind == inspect.Parameter.KEYWORD_ONLY
|
|
|
|
for param in params_to_check
|
|
|
|
)
|