mirror of
https://github.com/eternnoir/pyTelegramBotAPI.git
synced 2023-08-10 21:12:57 +03:00
Add edited message handler.
This commit is contained in:
parent
0b9f91c6fb
commit
8e3c9d8d24
@ -66,6 +66,7 @@ class TeleBot:
|
|||||||
self.pre_message_subscribers_next_step = {}
|
self.pre_message_subscribers_next_step = {}
|
||||||
|
|
||||||
self.message_handlers = []
|
self.message_handlers = []
|
||||||
|
self.edited_message_handlers = []
|
||||||
self.inline_handlers = []
|
self.inline_handlers = []
|
||||||
self.chosen_inline_handlers = []
|
self.chosen_inline_handlers = []
|
||||||
self.callback_query_handlers = []
|
self.callback_query_handlers = []
|
||||||
@ -123,6 +124,7 @@ class TeleBot:
|
|||||||
|
|
||||||
def process_new_updates(self, updates):
|
def process_new_updates(self, updates):
|
||||||
new_messages = []
|
new_messages = []
|
||||||
|
edited_new_messages = []
|
||||||
new_inline_querys = []
|
new_inline_querys = []
|
||||||
new_chosen_inline_results = []
|
new_chosen_inline_results = []
|
||||||
new_callback_querys = []
|
new_callback_querys = []
|
||||||
@ -131,6 +133,8 @@ class TeleBot:
|
|||||||
self.last_update_id = update.update_id
|
self.last_update_id = update.update_id
|
||||||
if update.message:
|
if update.message:
|
||||||
new_messages.append(update.message)
|
new_messages.append(update.message)
|
||||||
|
if update.edited_message:
|
||||||
|
edited_new_messages.append(update.edited_message)
|
||||||
if update.inline_query:
|
if update.inline_query:
|
||||||
new_inline_querys.append(update.inline_query)
|
new_inline_querys.append(update.inline_query)
|
||||||
if update.chosen_inline_result:
|
if update.chosen_inline_result:
|
||||||
@ -140,6 +144,8 @@ class TeleBot:
|
|||||||
logger.debug('Received {0} new updates'.format(len(updates)))
|
logger.debug('Received {0} new updates'.format(len(updates)))
|
||||||
if len(new_messages) > 0:
|
if len(new_messages) > 0:
|
||||||
self.process_new_messages(new_messages)
|
self.process_new_messages(new_messages)
|
||||||
|
if len(edited_new_messages) > 0:
|
||||||
|
self.process_new_edited_messages(edited_new_messages)
|
||||||
if len(new_inline_querys) > 0:
|
if len(new_inline_querys) > 0:
|
||||||
self.process_new_inline_query(new_inline_querys)
|
self.process_new_inline_query(new_inline_querys)
|
||||||
if len(new_chosen_inline_results) > 0:
|
if len(new_chosen_inline_results) > 0:
|
||||||
@ -154,6 +160,9 @@ class TeleBot:
|
|||||||
self._notify_message_subscribers(new_messages)
|
self._notify_message_subscribers(new_messages)
|
||||||
self._notify_message_next_handler(new_messages)
|
self._notify_message_next_handler(new_messages)
|
||||||
|
|
||||||
|
def process_new_edited_messages(self, edited_message):
|
||||||
|
self._notify_command_handlers(self.edited_message_handlers, edited_message)
|
||||||
|
|
||||||
def process_new_inline_query(self, new_inline_querys):
|
def process_new_inline_query(self, new_inline_querys):
|
||||||
self._notify_command_handlers(self.inline_handlers, new_inline_querys)
|
self._notify_command_handlers(self.inline_handlers, new_inline_querys)
|
||||||
|
|
||||||
@ -388,7 +397,8 @@ class TeleBot:
|
|||||||
apihelper.send_voice(self.token, chat_id, voice, duration, reply_to_message_id, reply_markup,
|
apihelper.send_voice(self.token, chat_id, voice, duration, reply_to_message_id, reply_markup,
|
||||||
disable_notification, timeout))
|
disable_notification, timeout))
|
||||||
|
|
||||||
def send_document(self, chat_id, data, reply_to_message_id=None, caption=None, reply_markup=None, disable_notification=None, timeout=None):
|
def send_document(self, chat_id, data, reply_to_message_id=None, caption=None, reply_markup=None,
|
||||||
|
disable_notification=None, timeout=None):
|
||||||
"""
|
"""
|
||||||
Use this method to send general files.
|
Use this method to send general files.
|
||||||
:param chat_id:
|
:param chat_id:
|
||||||
@ -401,7 +411,8 @@ class TeleBot:
|
|||||||
apihelper.send_data(self.token, chat_id, data, 'document', reply_to_message_id, reply_markup,
|
apihelper.send_data(self.token, chat_id, data, 'document', reply_to_message_id, reply_markup,
|
||||||
disable_notification, timeout, caption=caption))
|
disable_notification, timeout, caption=caption))
|
||||||
|
|
||||||
def send_sticker(self, chat_id, data, reply_to_message_id=None, reply_markup=None, disable_notification=None, timeout=None):
|
def send_sticker(self, chat_id, data, reply_to_message_id=None, reply_markup=None, disable_notification=None,
|
||||||
|
timeout=None):
|
||||||
"""
|
"""
|
||||||
Use this method to send .webp stickers.
|
Use this method to send .webp stickers.
|
||||||
:param chat_id:
|
:param chat_id:
|
||||||
@ -670,6 +681,32 @@ class TeleBot:
|
|||||||
|
|
||||||
self.message_handlers.append(handler_dict)
|
self.message_handlers.append(handler_dict)
|
||||||
|
|
||||||
|
def edited_message_handler(self, commands=None, regexp=None, func=None, content_types=['text']):
|
||||||
|
def decorator(handler):
|
||||||
|
self.add_edited_message_handler(handler, commands, regexp, func, content_types)
|
||||||
|
return handler
|
||||||
|
|
||||||
|
return decorator
|
||||||
|
|
||||||
|
def add_edited_message_handler(self, handler, commands=None, regexp=None, func=None, content_types=None):
|
||||||
|
if content_types is None:
|
||||||
|
content_types = ['text']
|
||||||
|
|
||||||
|
filters = {'content_types': content_types}
|
||||||
|
if regexp:
|
||||||
|
filters['regexp'] = regexp
|
||||||
|
if func:
|
||||||
|
filters['lambda'] = func
|
||||||
|
if commands:
|
||||||
|
filters['commands'] = commands
|
||||||
|
|
||||||
|
handler_dict = {
|
||||||
|
'function': handler,
|
||||||
|
'filters': filters
|
||||||
|
}
|
||||||
|
|
||||||
|
self.edited_message_handlers.append(handler_dict)
|
||||||
|
|
||||||
def inline_handler(self, func):
|
def inline_handler(self, func):
|
||||||
def decorator(handler):
|
def decorator(handler):
|
||||||
self.add_inline_handler(handler, func)
|
self.add_inline_handler(handler, func)
|
||||||
|
@ -91,21 +91,25 @@ class Update(JsonDeserializable):
|
|||||||
obj = cls.check_json(json_type)
|
obj = cls.check_json(json_type)
|
||||||
update_id = obj['update_id']
|
update_id = obj['update_id']
|
||||||
message = None
|
message = None
|
||||||
|
edited_message = None
|
||||||
inline_query = None
|
inline_query = None
|
||||||
chosen_inline_result = None
|
chosen_inline_result = None
|
||||||
callback_query = None
|
callback_query = None
|
||||||
if 'message' in obj:
|
if 'message' in obj:
|
||||||
message = Message.de_json(obj['message'])
|
message = Message.de_json(obj['message'])
|
||||||
|
if 'edited_message' in obj:
|
||||||
|
edited_message = Message.de_json(obj['edited_message'])
|
||||||
if 'inline_query' in obj:
|
if 'inline_query' in obj:
|
||||||
inline_query = InlineQuery.de_json(obj['inline_query'])
|
inline_query = InlineQuery.de_json(obj['inline_query'])
|
||||||
if 'chosen_inline_result' in obj:
|
if 'chosen_inline_result' in obj:
|
||||||
chosen_inline_result = ChosenInlineResult.de_json(obj['chosen_inline_result'])
|
chosen_inline_result = ChosenInlineResult.de_json(obj['chosen_inline_result'])
|
||||||
if 'callback_query' in obj:
|
if 'callback_query' in obj:
|
||||||
callback_query = CallbackQuery.de_json(obj['callback_query'])
|
callback_query = CallbackQuery.de_json(obj['callback_query'])
|
||||||
return cls(update_id, message, inline_query, chosen_inline_result, callback_query)
|
return cls(update_id, message, edited_message, inline_query, chosen_inline_result, callback_query)
|
||||||
|
|
||||||
def __init__(self, update_id, message, inline_query, chosen_inline_result, callback_query):
|
def __init__(self, update_id, message, edited_message, inline_query, chosen_inline_result, callback_query):
|
||||||
self.update_id = update_id
|
self.update_id = update_id
|
||||||
|
self.edited_message = edited_message
|
||||||
self.message = message
|
self.message = message
|
||||||
self.inline_query = inline_query
|
self.inline_query = inline_query
|
||||||
self.chosen_inline_result = chosen_inline_result
|
self.chosen_inline_result = chosen_inline_result
|
||||||
|
Loading…
Reference in New Issue
Block a user