1
0
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:
eternnoir 2016-06-07 19:29:12 +08:00
parent 0b9f91c6fb
commit 8e3c9d8d24
2 changed files with 48 additions and 7 deletions

View File

@ -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)

View File

@ -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