mirror of
https://github.com/eternnoir/pyTelegramBotAPI.git
synced 2023-08-10 21:12:57 +03:00
commit
389407e3ee
@ -3101,12 +3101,10 @@ class TeleBot:
|
|||||||
def add_custom_filter(self, custom_filter):
|
def add_custom_filter(self, custom_filter):
|
||||||
"""
|
"""
|
||||||
Create custom filter.
|
Create custom filter.
|
||||||
:params:
|
custom_filter: Class with check(message) method.
|
||||||
custom_filter: Class with check(message) method."""
|
"""
|
||||||
self.custom_filters[custom_filter.key] = custom_filter
|
self.custom_filters[custom_filter.key] = custom_filter
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def _test_filter(self, message_filter, filter_value, message):
|
def _test_filter(self, message_filter, filter_value, message):
|
||||||
"""
|
"""
|
||||||
Test filters
|
Test filters
|
||||||
@ -3133,23 +3131,22 @@ class TeleBot:
|
|||||||
return message.chat.type in filter_value
|
return message.chat.type in filter_value
|
||||||
elif message_filter == 'func':
|
elif message_filter == 'func':
|
||||||
return filter_value(message)
|
return filter_value(message)
|
||||||
else:
|
elif self.custom_filters and message_filter in self.custom_filters:
|
||||||
return self._check_filter(message_filter,filter_value,message)
|
return self._check_filter(message_filter,filter_value,message)
|
||||||
|
|
||||||
def _check_filter(self, message_filter, filter_value, message):
|
|
||||||
if message_filter in self.custom_filters:
|
|
||||||
filter_check = self.custom_filters.get(message_filter)
|
|
||||||
if isinstance(filter_value, util.SimpleCustomFilter):
|
|
||||||
|
|
||||||
if filter_value == filter_check.check(message): return True
|
|
||||||
else: return False
|
|
||||||
else:
|
|
||||||
if filter_check.check(message,filter_value) is True: return True
|
|
||||||
else: return False
|
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def _check_filter(self, message_filter, filter_value, message):
|
||||||
|
filter_check = self.custom_filters.get(message_filter)
|
||||||
|
if not filter_check:
|
||||||
|
return False
|
||||||
|
elif isinstance(filter_value, util.SimpleCustomFilter):
|
||||||
|
return filter_value == filter_check.check(message)
|
||||||
|
elif isinstance(filter_value, util.AdvancedCustomFilter):
|
||||||
|
return filter_check.check(message,filter_value)
|
||||||
|
else:
|
||||||
|
logger.error("Custom filter: wrong type. Should be SimpleCustomFilter or AdvancedCustomFilter.")
|
||||||
|
return False
|
||||||
|
|
||||||
def _notify_command_handlers(self, handlers, new_messages):
|
def _notify_command_handlers(self, handlers, new_messages):
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user