-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
executable file
·82 lines (64 loc) · 2.7 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#!/usr/bin/env python3
import typing
import logging.config
from telegram.ext import (
Updater, Dispatcher, CommandHandler,
CallbackQueryHandler, InlineQueryHandler
)
from mate_bot import err
from mate_bot import registry
from mate_bot.config import config
from mate_bot.commands.handler import FilteredChosenInlineResultHandler
from mate_bot.state.dbhelper import BackendHelper
handler_types = typing.Union[
typing.Type[CommandHandler],
typing.Type[CallbackQueryHandler],
typing.Type[InlineQueryHandler],
typing.Type[FilteredChosenInlineResultHandler]
]
def _add(dispatcher: Dispatcher, handler: handler_types, pool: dict, pattern: bool = True) -> None:
"""
Add the executors from the given pool to the dispatcher using the given handler type
:param dispatcher: Telegram's dispatcher to add the executor to
:type dispatcher: telegram.ext.Dispatcher
:param handler: type of the handler (subclass of ``telegram.ext.Handler``)
:type handler: handler_types
:param pool: collection of all executors for one handler type
:type pool: dict
:param pattern: switch whether the keys of the pool are patterns or names
:type pattern: bool
:return: None
"""
logger.info(f"Adding {handler.__name__} executors...")
for name in pool:
if pattern:
dispatcher.add_handler(handler(pool[name], pattern=name))
else:
dispatcher.add_handler(handler(name, pool[name]))
class NoDebugFilter(logging.Filter):
"""
Logging filter that filters out any DEBUG message for the specified logger or handler
"""
def filter(self, record: logging.LogRecord) -> int:
if super().filter(record):
return record.levelno > logging.DEBUG
return True
if __name__ == "__main__":
logging.config.dictConfig(config["logging"])
for handler in logging.root.handlers:
handler.addFilter(NoDebugFilter("telegram"))
logger = logging.getLogger()
BackendHelper.db_config = config["database"]
BackendHelper.query_logger = logging.getLogger("database")
BackendHelper.get_value("users")
logger.debug("Registering bot token with Updater...")
updater = Updater(config["token"], use_context = True)
logger.info("Adding error handler...")
updater.dispatcher.add_error_handler(err.log_error)
_add(updater.dispatcher, CommandHandler, registry.commands, False)
_add(updater.dispatcher, CallbackQueryHandler, registry.callback_queries, True)
_add(updater.dispatcher, InlineQueryHandler, registry.inline_queries, True)
_add(updater.dispatcher, FilteredChosenInlineResultHandler, registry.inline_results, True)
logger.info("Starting bot...")
updater.start_polling()
updater.idle()