mirror of
https://github.com/eternnoir/pyTelegramBotAPI.git
synced 2023-08-10 21:12:57 +03:00
new 5.3 function names
added the new function names (the previous names are still working) from 5.3 and some other small changes
This commit is contained in:
parent
72ed7c1dde
commit
0aa7a8a8f6
@ -104,6 +104,7 @@ class TeleBot:
|
|||||||
editMessageLiveLocation
|
editMessageLiveLocation
|
||||||
stopMessageLiveLocation
|
stopMessageLiveLocation
|
||||||
kickChatMember
|
kickChatMember
|
||||||
|
banChatMember
|
||||||
unbanChatMember
|
unbanChatMember
|
||||||
restrictChatMember
|
restrictChatMember
|
||||||
promoteChatMember
|
promoteChatMember
|
||||||
@ -132,10 +133,12 @@ class TeleBot:
|
|||||||
getChat
|
getChat
|
||||||
getChatAdministrators
|
getChatAdministrators
|
||||||
getChatMembersCount
|
getChatMembersCount
|
||||||
|
getChatMemberCount
|
||||||
getChatMember
|
getChatMember
|
||||||
answerCallbackQuery
|
answerCallbackQuery
|
||||||
getMyCommands
|
getMyCommands
|
||||||
setMyCommands
|
setMyCommands
|
||||||
|
deleteMyCommands
|
||||||
answerInlineQuery
|
answerInlineQuery
|
||||||
answerShippingQuery
|
answerShippingQuery
|
||||||
answerPreCheckoutQuery
|
answerPreCheckoutQuery
|
||||||
@ -845,6 +848,15 @@ class TeleBot:
|
|||||||
result = apihelper.get_chat_members_count(self.token, chat_id)
|
result = apihelper.get_chat_members_count(self.token, chat_id)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
def get_chat_member_count(self, chat_id: Union[int, str]) -> int:
|
||||||
|
"""
|
||||||
|
Use this method to get the number of members in a chat. Returns Int on success.
|
||||||
|
:param chat_id:
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
|
result = apihelper.get_chat_member_count(self.token, chat_id)
|
||||||
|
return result
|
||||||
|
|
||||||
def set_chat_sticker_set(self, chat_id: Union[int, str], sticker_set_name: str) -> types.StickerSet:
|
def set_chat_sticker_set(self, chat_id: Union[int, str], sticker_set_name: str) -> types.StickerSet:
|
||||||
"""
|
"""
|
||||||
Use this method to set a new group sticker set for a supergroup. The bot must be an administrator
|
Use this method to set a new group sticker set for a supergroup. The bot must be an administrator
|
||||||
@ -1475,6 +1487,26 @@ class TeleBot:
|
|||||||
"""
|
"""
|
||||||
return apihelper.kick_chat_member(self.token, chat_id, user_id, until_date, revoke_messages)
|
return apihelper.kick_chat_member(self.token, chat_id, user_id, until_date, revoke_messages)
|
||||||
|
|
||||||
|
def ban_chat_member(
|
||||||
|
self, chat_id: Union[int, str], user_id: int,
|
||||||
|
until_date:Optional[Union[int, datetime]]=None,
|
||||||
|
revoke_messages: Optional[bool]=None) -> bool:
|
||||||
|
"""
|
||||||
|
Use this method to ban a user in a group, a supergroup or a channel.
|
||||||
|
In the case of supergroups and channels, the user will not be able to return to the chat on their
|
||||||
|
own using invite links, etc., unless unbanned first.
|
||||||
|
Returns True on success.
|
||||||
|
:param chat_id: Int or string : Unique identifier for the target group or username of the target supergroup
|
||||||
|
:param user_id: Int : Unique identifier of the target user
|
||||||
|
:param until_date: Date when the user will be unbanned, unix time. If user is banned for more than 366 days or
|
||||||
|
less than 30 seconds from the current time they are considered to be banned forever
|
||||||
|
:param revoke_messages: Bool: Pass True to delete all messages from the chat for the user that is being removed.
|
||||||
|
If False, the user will be able to see messages in the group that were sent before the user was removed.
|
||||||
|
Always True for supergroups and channels.
|
||||||
|
:return: boolean
|
||||||
|
"""
|
||||||
|
return apihelper.ban_chat_member(self.token, chat_id, user_id, until_date, revoke_messages)
|
||||||
|
|
||||||
def unban_chat_member(
|
def unban_chat_member(
|
||||||
self, chat_id: Union[int, str], user_id: int,
|
self, chat_id: Union[int, str], user_id: int,
|
||||||
only_if_banned: Optional[bool]=False) -> bool:
|
only_if_banned: Optional[bool]=False) -> bool:
|
||||||
@ -1699,54 +1731,49 @@ class TeleBot:
|
|||||||
setting is off in the target group.
|
setting is off in the target group.
|
||||||
:param chat_id: Int or Str: Unique identifier for the target chat or username of the target channel
|
:param chat_id: Int or Str: Unique identifier for the target chat or username of the target channel
|
||||||
(in the format @channelusername)
|
(in the format @channelusername)
|
||||||
:return:
|
|
||||||
"""
|
"""
|
||||||
return apihelper.delete_chat_photo(self.token, chat_id)
|
return apihelper.delete_chat_photo(self.token, chat_id)
|
||||||
|
|
||||||
def get_my_commands(self,
|
def get_my_commands(self, scope: Optional[types.BotCommandScope],
|
||||||
scope: Optional[Union[
|
language_code: Optional[str]) -> List[types.BotCommand]:
|
||||||
types.BotCommandScopeDefault, types.BotCommandScopeAllPrivateChats,
|
|
||||||
types.BotCommandScopeAllGroupChats, types.BotCommandScopeAllChatAdministrators,
|
|
||||||
types.BotCommandScopeChat,
|
|
||||||
types.BotCommandScopeChatAdministrators, types.BotCommandScopeChatMember]]=None,
|
|
||||||
language_code: Optional[str]=None) -> List[types.BotCommand]:
|
|
||||||
"""
|
"""
|
||||||
Use this method to get the current list of the bot's commands for the given scope and user language
|
Use this method to get the current list of the bot's commands.
|
||||||
:param scope: scope of users for which the commands are relevant
|
|
||||||
:param language_code: A two-letter ISO 639-1 language code
|
|
||||||
Returns List of BotCommand on success.
|
Returns List of BotCommand on success.
|
||||||
|
:param scope: The scope of users for which the commands are relevant.
|
||||||
|
Defaults to BotCommandScopeDefault.
|
||||||
|
:param language_code: A two-letter ISO 639-1 language code. If empty,
|
||||||
|
commands will be applied to all users from the given scope,
|
||||||
|
for whose language there are no dedicated commands
|
||||||
"""
|
"""
|
||||||
result = apihelper.get_my_commands(self.token, scope, language_code)
|
result = apihelper.get_my_commands(self.token, scope, language_code)
|
||||||
return [types.BotCommand.de_json(cmd) for cmd in result]
|
return [types.BotCommand.de_json(cmd) for cmd in result]
|
||||||
|
|
||||||
def set_my_commands(self, commands: List[types.BotCommand],
|
def set_my_commands(self, commands: List[types.BotCommand],
|
||||||
scope: Optional[Union[
|
scope: Optional[types.BotCommandScope]=None,
|
||||||
types.BotCommandScopeDefault, types.BotCommandScopeAllPrivateChats,
|
|
||||||
types.BotCommandScopeAllGroupChats, types.BotCommandScopeAllChatAdministrators,
|
|
||||||
types.BotCommandScopeChat,
|
|
||||||
types.BotCommandScopeChatAdministrators, types.BotCommandScopeChatMember]] = None,
|
|
||||||
language_code: Optional[str]=None) -> bool:
|
language_code: Optional[str]=None) -> bool:
|
||||||
"""
|
"""
|
||||||
Use this method to change the list of the bot's commands.
|
Use this method to change the list of the bot's commands.
|
||||||
:param commands: List of BotCommand. At most 100 commands can be specified.
|
:param commands: List of BotCommand. At most 100 commands can be specified.
|
||||||
:param scope: scope of users for which the commands are relevant
|
:param scope: The scope of users for which the commands are relevant.
|
||||||
:param language_code: A two-letter ISO 639-1 language code
|
Defaults to BotCommandScopeDefault.
|
||||||
|
:param language_code: A two-letter ISO 639-1 language code. If empty,
|
||||||
|
commands will be applied to all users from the given scope,
|
||||||
|
for whose language there are no dedicated commands
|
||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
return apihelper.set_my_commands(self.token, commands, scope, language_code)
|
return apihelper.set_my_commands(self.token, commands, scope, language_code)
|
||||||
|
|
||||||
def delete_my_commands(self,
|
def delete_my_commands(self, scope: Optional[types.BotCommandScope]=None,
|
||||||
scope: Optional[Union[
|
language_code: Optional[int]=None) -> bool:
|
||||||
types.BotCommandScopeDefault, types.BotCommandScopeAllPrivateChats,
|
|
||||||
types.BotCommandScopeAllGroupChats, types.BotCommandScopeAllChatAdministrators,
|
|
||||||
types.BotCommandScopeChat,
|
|
||||||
types.BotCommandScopeChatAdministrators, types.BotCommandScopeChatMember]]=None,
|
|
||||||
language_code: Optional[str]=None) -> bool:
|
|
||||||
"""
|
"""
|
||||||
Use this method to delete the list of the bot's commands for the given scope and user language.
|
Use this method to delete the list of the bot's commands for the given scope and user language.
|
||||||
:param scope: scope of users for which the commands are relevant
|
After deletion, higher level commands will be shown to affected users.
|
||||||
:param language_code: A two-letter ISO 639-1 language code
|
Returns True on success.
|
||||||
:return:
|
:param scope: The scope of users for which the commands are relevant.
|
||||||
|
Defaults to BotCommandScopeDefault.
|
||||||
|
:param language_code: A two-letter ISO 639-1 language code. If empty,
|
||||||
|
commands will be applied to all users from the given scope,
|
||||||
|
for whose language there are no dedicated commands
|
||||||
"""
|
"""
|
||||||
return apihelper.delete_my_commands(self.token, scope, language_code)
|
return apihelper.delete_my_commands(self.token, scope, language_code)
|
||||||
|
|
||||||
@ -2907,13 +2934,17 @@ class AsyncTeleBot(TeleBot):
|
|||||||
return TeleBot.close(self)
|
return TeleBot.close(self)
|
||||||
|
|
||||||
@util.async_dec()
|
@util.async_dec()
|
||||||
def get_my_commands(self):
|
def get_my_commands(self, *args, **kwargs): # needed args because new scope and language_code
|
||||||
return TeleBot.get_my_commands(self)
|
return TeleBot.get_my_commands(self, *args, **kwargs)
|
||||||
|
|
||||||
@util.async_dec()
|
@util.async_dec()
|
||||||
def set_my_commands(self, *args, **kwargs):
|
def set_my_commands(self, *args, **kwargs):
|
||||||
return TeleBot.set_my_commands(self, *args, **kwargs)
|
return TeleBot.set_my_commands(self, *args, **kwargs)
|
||||||
|
|
||||||
|
@util.async_dec()
|
||||||
|
def delete_my_commands(self, *args, **kwargs):
|
||||||
|
return TeleBot.delete_my_commands(self, *args, **kwargs)
|
||||||
|
|
||||||
@util.async_dec()
|
@util.async_dec()
|
||||||
def get_file(self, *args):
|
def get_file(self, *args):
|
||||||
return TeleBot.get_file(self, *args)
|
return TeleBot.get_file(self, *args)
|
||||||
@ -2942,6 +2973,10 @@ class AsyncTeleBot(TeleBot):
|
|||||||
def get_chat_members_count(self, *args):
|
def get_chat_members_count(self, *args):
|
||||||
return TeleBot.get_chat_members_count(self, *args)
|
return TeleBot.get_chat_members_count(self, *args)
|
||||||
|
|
||||||
|
@util.async_dec()
|
||||||
|
def get_chat_member_count(self, *args):
|
||||||
|
return TeleBot.get_chat_member_count(self, *args)
|
||||||
|
|
||||||
@util.async_dec()
|
@util.async_dec()
|
||||||
def set_chat_sticker_set(self, *args):
|
def set_chat_sticker_set(self, *args):
|
||||||
return TeleBot.set_chat_sticker_set(self, *args)
|
return TeleBot.set_chat_sticker_set(self, *args)
|
||||||
@ -3038,6 +3073,10 @@ class AsyncTeleBot(TeleBot):
|
|||||||
def kick_chat_member(self, *args, **kwargs):
|
def kick_chat_member(self, *args, **kwargs):
|
||||||
return TeleBot.kick_chat_member(self, *args, **kwargs)
|
return TeleBot.kick_chat_member(self, *args, **kwargs)
|
||||||
|
|
||||||
|
@util.async_dec()
|
||||||
|
def ban_chat_member(self, *args, **kwargs):
|
||||||
|
return TeleBot.ban_chat_member(self, *args, **kwargs)
|
||||||
|
|
||||||
@util.async_dec()
|
@util.async_dec()
|
||||||
def unban_chat_member(self, *args, **kwargs):
|
def unban_chat_member(self, *args, **kwargs):
|
||||||
return TeleBot.unban_chat_member(self, *args, **kwargs)
|
return TeleBot.unban_chat_member(self, *args, **kwargs)
|
||||||
|
@ -93,6 +93,7 @@ def _make_request(token, method_name, method='get', params=None, files=None):
|
|||||||
# Long polling hangs for given time. Read timeout should be greater that long_polling_timeout
|
# Long polling hangs for given time. Read timeout should be greater that long_polling_timeout
|
||||||
read_timeout = max(params['timeout'] + 10, read_timeout)
|
read_timeout = max(params['timeout'] + 10, read_timeout)
|
||||||
|
|
||||||
|
params = params or None #set params to None if empty
|
||||||
|
|
||||||
result = None
|
result = None
|
||||||
if RETRY_ON_ERROR:
|
if RETRY_ON_ERROR:
|
||||||
@ -335,6 +336,12 @@ def get_chat_members_count(token, chat_id):
|
|||||||
return _make_request(token, method_url, params=payload)
|
return _make_request(token, method_url, params=payload)
|
||||||
|
|
||||||
|
|
||||||
|
def get_chat_member_count(token, chat_id):
|
||||||
|
method_url = r'getChatMemberCount'
|
||||||
|
payload = {'chat_id': chat_id}
|
||||||
|
return _make_request(token, method_url, params=payload)
|
||||||
|
|
||||||
|
|
||||||
def set_sticker_set_thumb(token, name, user_id, thumb):
|
def set_sticker_set_thumb(token, name, user_id, thumb):
|
||||||
method_url = r'setStickerSetThumb'
|
method_url = r'setStickerSetThumb'
|
||||||
payload = {'name': name, 'user_id': user_id}
|
payload = {'name': name, 'user_id': user_id}
|
||||||
@ -861,6 +868,18 @@ def kick_chat_member(token, chat_id, user_id, until_date=None, revoke_messages=N
|
|||||||
return _make_request(token, method_url, params=payload, method='post')
|
return _make_request(token, method_url, params=payload, method='post')
|
||||||
|
|
||||||
|
|
||||||
|
def ban_chat_member(token, chat_id, user_id, until_date=None, revoke_messages=None):
|
||||||
|
method_url = 'banChatMember'
|
||||||
|
payload = {'chat_id': chat_id, 'user_id': user_id}
|
||||||
|
if isinstance(until_date, datetime):
|
||||||
|
payload['until_date'] = until_date.timestamp()
|
||||||
|
else:
|
||||||
|
payload['until_date'] = until_date
|
||||||
|
if revoke_messages is not None:
|
||||||
|
payload['revoke_messages'] = revoke_messages
|
||||||
|
return _make_request(token, method_url, params=payload, method='post')
|
||||||
|
|
||||||
|
|
||||||
def unban_chat_member(token, chat_id, user_id, only_if_banned):
|
def unban_chat_member(token, chat_id, user_id, only_if_banned):
|
||||||
method_url = 'unbanChatMember'
|
method_url = 'unbanChatMember'
|
||||||
payload = {'chat_id': chat_id, 'user_id': user_id}
|
payload = {'chat_id': chat_id, 'user_id': user_id}
|
||||||
@ -1027,32 +1046,32 @@ def set_chat_title(token, chat_id, title):
|
|||||||
return _make_request(token, method_url, params=payload, method='post')
|
return _make_request(token, method_url, params=payload, method='post')
|
||||||
|
|
||||||
|
|
||||||
def get_my_commands(token, scope, language_code):
|
def get_my_commands(token, scope=None, language_code=None):
|
||||||
method_url = r'getMyCommands'
|
method_url = r'getMyCommands'
|
||||||
payload = {}
|
payload = {}
|
||||||
if scope is not None:
|
if scope:
|
||||||
payload['scope'] = scope.to_json()
|
payload['scope'] = scope.to_json()
|
||||||
if language_code is not None:
|
if language_code:
|
||||||
payload['language_code'] = language_code
|
payload['language_code'] = language_code
|
||||||
return _make_request(token, method_url, params=payload, method='post')
|
return _make_request(token, method_url, params=payload)
|
||||||
|
|
||||||
|
|
||||||
def set_my_commands(token, commands, scope, language_code):
|
def set_my_commands(token, commands, scope=None, language_code=None):
|
||||||
method_url = r'setMyCommands'
|
method_url = r'setMyCommands'
|
||||||
payload = {'commands': _convert_list_json_serializable(commands)}
|
payload = {'commands': _convert_list_json_serializable(commands)}
|
||||||
if scope is not None:
|
if scope:
|
||||||
payload['scope'] = scope.to_json()
|
payload['scope'] = scope.to_json()
|
||||||
if language_code is not None:
|
if language_code:
|
||||||
payload['language_code'] = language_code
|
payload['language_code'] = language_code
|
||||||
return _make_request(token, method_url, params=payload, method='post')
|
return _make_request(token, method_url, params=payload, method='post')
|
||||||
|
|
||||||
|
|
||||||
def delete_my_commands(token, scope, language_code):
|
def delete_my_commands(token, scope=None, language_code=None):
|
||||||
method_url = r'deleteMyCommands'
|
method_url = r'deleteMyCommands'
|
||||||
payload = {}
|
payload = {}
|
||||||
if scope is not None:
|
if scope:
|
||||||
payload['scope'] = scope.to_json()
|
payload['scope'] = scope.to_json()
|
||||||
if language_code is not None:
|
if language_code:
|
||||||
payload['language_code'] = language_code
|
payload['language_code'] = language_code
|
||||||
return _make_request(token, method_url, params=payload, method='post')
|
return _make_request(token, method_url, params=payload, method='post')
|
||||||
|
|
||||||
|
@ -849,13 +849,13 @@ class File(JsonDeserializable):
|
|||||||
|
|
||||||
|
|
||||||
class ForceReply(JsonSerializable):
|
class ForceReply(JsonSerializable):
|
||||||
def __init__(self, selective=None, input_field_placeholder=None):
|
def __init__(self, selective: Optional[bool]=None, input_field_placeholder: Optional[str]=None):
|
||||||
self.selective: bool = selective
|
self.selective: bool = selective
|
||||||
self.input_field_placeholder = input_field_placeholder
|
self.input_field_placeholder: str = input_field_placeholder
|
||||||
|
|
||||||
def to_json(self):
|
def to_json(self):
|
||||||
json_dict = {'force_reply': True}
|
json_dict = {'force_reply': True}
|
||||||
if self.selective:
|
if self.selective is not None:
|
||||||
json_dict['selective'] = True
|
json_dict['selective'] = True
|
||||||
if self.input_field_placeholder:
|
if self.input_field_placeholder:
|
||||||
json_dict['input_field_placeholder'] = self.input_field_placeholder
|
json_dict['input_field_placeholder'] = self.input_field_placeholder
|
||||||
@ -876,8 +876,8 @@ class ReplyKeyboardRemove(JsonSerializable):
|
|||||||
class ReplyKeyboardMarkup(JsonSerializable):
|
class ReplyKeyboardMarkup(JsonSerializable):
|
||||||
max_row_keys = 12
|
max_row_keys = 12
|
||||||
|
|
||||||
def __init__(self, resize_keyboard=None, one_time_keyboard=None, selective=None, row_width=3,
|
def __init__(self, resize_keyboard: Optional[bool]=None, one_time_keyboard: Optional[bool]=None,
|
||||||
input_field_placeholder=None):
|
selective: Optional[bool]=None, row_width: int=3, input_field_placeholder: Optional[str]=None):
|
||||||
if row_width > self.max_row_keys:
|
if row_width > self.max_row_keys:
|
||||||
# Todo: Will be replaced with Exception in future releases
|
# Todo: Will be replaced with Exception in future releases
|
||||||
if not DISABLE_KEYLEN_ERROR:
|
if not DISABLE_KEYLEN_ERROR:
|
||||||
@ -888,7 +888,7 @@ class ReplyKeyboardMarkup(JsonSerializable):
|
|||||||
self.one_time_keyboard: bool = one_time_keyboard
|
self.one_time_keyboard: bool = one_time_keyboard
|
||||||
self.selective: bool = selective
|
self.selective: bool = selective
|
||||||
self.row_width: int = row_width
|
self.row_width: int = row_width
|
||||||
self.input_field_placeholder = input_field_placeholder
|
self.input_field_placeholder: str = input_field_placeholder
|
||||||
self.keyboard: List[List[KeyboardButton]] = []
|
self.keyboard: List[List[KeyboardButton]] = []
|
||||||
|
|
||||||
def add(self, *args, row_width=None):
|
def add(self, *args, row_width=None):
|
||||||
@ -942,11 +942,11 @@ class ReplyKeyboardMarkup(JsonSerializable):
|
|||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
json_dict = {'keyboard': self.keyboard}
|
json_dict = {'keyboard': self.keyboard}
|
||||||
if self.one_time_keyboard:
|
if self.one_time_keyboard is not None:
|
||||||
json_dict['one_time_keyboard'] = True
|
json_dict['one_time_keyboard'] = True
|
||||||
if self.resize_keyboard:
|
if self.resize_keyboard is not None:
|
||||||
json_dict['resize_keyboard'] = True
|
json_dict['resize_keyboard'] = True
|
||||||
if self.selective:
|
if self.selective is not None:
|
||||||
json_dict['selective'] = True
|
json_dict['selective'] = True
|
||||||
if self.input_field_placeholder:
|
if self.input_field_placeholder:
|
||||||
json_dict['input_field_placeholder'] = self.input_field_placeholder
|
json_dict['input_field_placeholder'] = self.input_field_placeholder
|
||||||
@ -954,7 +954,8 @@ class ReplyKeyboardMarkup(JsonSerializable):
|
|||||||
|
|
||||||
|
|
||||||
class KeyboardButton(Dictionaryable, JsonSerializable):
|
class KeyboardButton(Dictionaryable, JsonSerializable):
|
||||||
def __init__(self, text, request_contact=None, request_location=None, request_poll=None):
|
def __init__(self, text: str, request_contact: Optional[bool]=None,
|
||||||
|
request_location: Optional[bool]=None, request_poll: Optional[bool]=None):
|
||||||
self.text: str = text
|
self.text: str = text
|
||||||
self.request_contact: bool = request_contact
|
self.request_contact: bool = request_contact
|
||||||
self.request_location: bool = request_location
|
self.request_location: bool = request_location
|
||||||
@ -965,11 +966,11 @@ class KeyboardButton(Dictionaryable, JsonSerializable):
|
|||||||
|
|
||||||
def to_dict(self):
|
def to_dict(self):
|
||||||
json_dict = {'text': self.text}
|
json_dict = {'text': self.text}
|
||||||
if self.request_contact:
|
if self.request_contact is not None:
|
||||||
json_dict['request_contact'] = self.request_contact
|
json_dict['request_contact'] = self.request_contact
|
||||||
if self.request_location:
|
if self.request_location is not None:
|
||||||
json_dict['request_location'] = self.request_location
|
json_dict['request_location'] = self.request_location
|
||||||
if self.request_poll:
|
if self.request_poll is not None:
|
||||||
json_dict['request_poll'] = self.request_poll.to_dict()
|
json_dict['request_poll'] = self.request_poll.to_dict()
|
||||||
return json_dict
|
return json_dict
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user