Dispatcher Module¶
Dispatcher(router_id=None, storage=MemoryContext, *, use_create_task=False, **storage_kwargs)
¶
Bases: BotMixin
Основной класс для обработки событий бота.
Обеспечивает запуск поллинга и вебхука, маршрутизацию событий, применение middleware, фильтров и вызов соответствующих обработчиков.
Инициализация диспетчера.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
router_id
|
str | None
|
Идентификатор роутера для логов. |
None
|
use_create_task
|
bool
|
Флаг, отвечающий за параллелизацию обработок событий. |
False
|
storage
|
Any
|
Класс контекста для хранения данных (MemoryContext, RedisContext и т.д.). |
MemoryContext
|
**storage_kwargs
|
Any
|
Дополнительные аргументы для инициализации хранилища. |
{}
|
Source code in maxapi/dispatcher.py
95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 | |
middlewares
property
writable
¶
Список outer-middleware.
.. deprecated::
Используйте :attr:outer_middlewares.
check_me()
async
¶
Проверяет и логирует информацию о боте.
Source code in maxapi/dispatcher.py
build_middleware_chain(middlewares, handler)
staticmethod
¶
Формирует цепочку вызова middleware вокруг хендлера.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
middlewares
|
list[BaseMiddleware]
|
Список middleware. |
required |
handler
|
HandlerCallable
|
Финальный обработчик. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
Callable |
HandlerCallable
|
Обёрнутый обработчик. |
Source code in maxapi/dispatcher.py
include_routers(*routers)
¶
Добавляет указанные роутеры в диспетчер.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
*routers
|
Router
|
Роутеры для добавления. |
()
|
register_outer_middleware(middleware)
¶
Регистрирует outer middleware (до проверки фильтров handler).
Вызывается для каждого подходящего события ещё до того, как диспетчер узнает, какой именно handler сработает.
Порядок регистрации сохраняется: первый зарегистрированный
outer middleware выполняется первым (внешний слой цепочки),
что симметрично с :meth:register_inner_middleware.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
middleware
|
BaseMiddleware
|
Middleware. |
required |
Source code in maxapi/dispatcher.py
register_inner_middleware(middleware)
¶
Регистрирует inner middleware (после проверки фильтров handler).
Вызывается только тогда, когда конкретный handler прошёл все свои фильтры и state и будет реально исполнен. На уровне Dispatcher — только для событий, попавших хоть в один handler; на уровне Router — только для handler этого роутера.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
middleware
|
BaseMiddleware
|
Middleware. |
required |
Source code in maxapi/dispatcher.py
outer_middleware(middleware)
¶
Добавляет Middleware на первое место в списке outer_middlewares.
Историческое поведение: insert(0, ...). В новом
:meth:register_outer_middleware порядок изменён на append
(register order = execution order), поэтому при миграции
проверьте порядок вызовов, если он важен.
.. deprecated::
Используйте :meth:register_outer_middleware.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
middleware
|
BaseMiddleware
|
Middleware. |
required |
Source code in maxapi/dispatcher.py
middleware(middleware)
¶
Добавляет Middleware в конец списка.
.. deprecated::
Используйте :meth:register_outer_middleware (текущее
поведение — outer, до фильтров handler) или
:meth:register_inner_middleware (только когда handler
реально вызван).
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
middleware
|
BaseMiddleware
|
Middleware. |
required |
Source code in maxapi/dispatcher.py
filter(base_filter)
¶
Добавляет фильтр в список.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
base_filter
|
BaseFilter
|
Фильтр. |
required |
__ready(bot)
async
¶
Подготавливает диспетчер: сохраняет бота, подготавливает обработчики, вызывает on_started.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bot
|
Bot
|
Экземпляр бота. |
required |
Source code in maxapi/dispatcher.py
__get_context(chat_id, user_id)
¶
Возвращает существующий или создаёт новый контекст по chat_id и user_id.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
chat_id
|
int | None
|
Идентификатор чата. |
required |
user_id
|
int | None
|
Идентификатор пользователя. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
BaseContext |
BaseContext
|
Контекст. |
Source code in maxapi/dispatcher.py
call_handler(handler, event_object, data)
async
staticmethod
¶
Вызывает хендлер с нужными аргументами.
Перед вызовом фильтрует data, оставляя только те ключи,
которые handler реально принимает (по handler.func_args или
параметрам, полученным через :func:inspect.signature).
В отличие от get_annotations, signature не включает
"return" и не требует eval строковых аннотаций — безопасен
при from __future__ import annotations. Несовместимые ключи
не дойдут до handler и не приведут к TypeError.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
handler
|
Handler
|
Handler. |
required |
event_object
|
UpdateUnion | dict[str, Any]
|
Объект события. |
required |
data
|
dict[str, Any]
|
Данные, накопленные фильтрами и middleware. |
required |
Returns:
| Type | Description |
|---|---|
None
|
None |
Source code in maxapi/dispatcher.py
process_base_filters(event, filters, data=None)
async
staticmethod
¶
Асинхронно применяет фильтры к событию.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
event
|
UpdateUnion
|
Событие. |
required |
filters
|
list[BaseFilter]
|
Список фильтров. |
required |
Returns:
| Type | Description |
|---|---|
dict[str, Any] | None
|
dict[str, Any] | None: Словарь с результатом или None, если фильтр не прошёл. |
Source code in maxapi/dispatcher.py
handle_raw_response(event_type, raw_data)
async
¶
Специальный метод для обработки сырых ответов API.
Source code in maxapi/dispatcher.py
handle(event_object)
async
¶
Основной обработчик события. Применяет фильтры, middleware и вызывает нужный handler.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
event_object
|
UpdateUnion
|
Событие. |
required |
Source code in maxapi/dispatcher.py
1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 | |
start_polling(bot, *, skip_updates=False)
async
¶
Запускает цикл получения обновлений (long polling).
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bot
|
Bot
|
Экземпляр бота. |
required |
skip_updates
|
bool
|
Флаг, отвечающий за обработку старых событий. |
False
|
Source code in maxapi/dispatcher.py
stop_polling()
async
¶
Останавливает цикл получения обновлений (long polling).
Дожидается завершения всех фоновых задач (use_create_task=True), запущенных до момента остановки.
Source code in maxapi/dispatcher.py
startup(bot)
async
¶
Инициализирует диспетчер: сохраняет бота, подготавливает обработчики и вызывает on_started.
Используется интеграционными модулями (например, maxapi.webhook.fastapi) для инициализации в lifespan веб-фреймворка.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bot
|
Bot
|
Экземпляр бота. |
required |
Source code in maxapi/dispatcher.py
handle_webhook(bot, *, host=DEFAULT_HOST, port=DEFAULT_PORT, path=DEFAULT_PATH, secret=None, webhook_type=AiohttpMaxWebhook, **kwargs)
async
¶
Запускает вебхук-сервер (aiohttp) для приёма обновлений.
Удобный метод «всё в одном»: создаёт aiohttp-приложение через
:class:~maxapi.webhook.aiohttp.BaseMaxWebhook,
регистрирует маршрут и запускает сервер.
Для более гибкого управления жизненным циклом сервера используйте
одну из реализаций BaseMaxWebhook напрямую, например
:class:~maxapi.webhook.aiohttp.BaseMaxWebhook.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bot
|
Bot
|
Экземпляр бота. |
required |
host
|
str
|
Хост сервера (по умолчанию |
DEFAULT_HOST
|
port
|
int
|
Порт сервера (по умолчанию |
DEFAULT_PORT
|
path
|
str
|
URL-путь для маршрута вебхука. |
DEFAULT_PATH
|
secret
|
str | None
|
Секрет для проверки заголовка
|
None
|
webhook_type
|
type[BaseMaxWebhook]
|
Класс вебхука. |
AiohttpMaxWebhook
|
**kwargs
|
Any
|
Дополнительные аргументы для |
{}
|
Source code in maxapi/dispatcher.py
init_serve(bot, host=DEFAULT_HOST, port=DEFAULT_PORT, **kwargs)
async
¶
.. deprecated::
Используйте :meth:handle_webhook вместо init_serve.
Метод будет удалён в одной из следующих версий.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bot
|
Bot
|
Экземпляр бота. |
required |
host
|
str
|
Хост. |
DEFAULT_HOST
|
port
|
int
|
Порт. |
DEFAULT_PORT
|
Source code in maxapi/dispatcher.py
Router(router_id=None)
¶
Bases: Dispatcher
Роутер для группировки обработчиков событий.
Инициализация роутера.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
router_id
|
str | None
|
Идентификатор роутера для логов. |
None
|
Source code in maxapi/dispatcher.py
Event(update_type, router, *, deprecated=False)
¶
Декоратор для регистрации обработчиков событий.
Инициализирует событие-декоратор.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
update_type
|
UpdateType
|
Тип события. |
required |
router
|
Dispatcher | Router
|
Экземпляр роутера или диспетчера. |
required |
deprecated
|
bool
|
Флаг, указывающий на то, что событие устарело. |
False
|
Source code in maxapi/dispatcher.py
register(func_event, *args, **kwargs)
¶
Регистрирует функцию как обработчик события.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
func_event
|
Callable
|
Функция-обработчик |
required |
*args
|
Any
|
Фильтры |
()
|
**kwargs
|
Any
|
Дополнительные параметры (например, states) |
{}
|
Returns:
| Name | Type | Description |
|---|---|---|
Callable |
Callable
|
Исходная функция. |
Source code in maxapi/dispatcher.py
__call__(*args, **kwargs)
¶
Регистрирует функцию как обработчик события через декоратор.
Returns:
| Name | Type | Description |
|---|---|---|
Callable |
Callable
|
Декоратор. |