mirror of
https://github.com/aiogram/aiogram.git
synced 2025-12-11 18:01:04 +00:00
Allow to get current handler
This commit is contained in:
parent
5aff7f7d35
commit
5be3f9d00b
2 changed files with 10 additions and 7 deletions
|
|
@ -2,13 +2,14 @@ import inspect
|
|||
from contextvars import ContextVar
|
||||
|
||||
ctx_data = ContextVar('ctx_handler_data')
|
||||
current_handler = ContextVar('current_handler')
|
||||
|
||||
|
||||
class SkipHandler(BaseException):
|
||||
class SkipHandler(Exception):
|
||||
pass
|
||||
|
||||
|
||||
class CancelHandler(BaseException):
|
||||
class CancelHandler(Exception):
|
||||
pass
|
||||
|
||||
|
||||
|
|
@ -87,9 +88,9 @@ class Handler:
|
|||
except FilterNotPassed:
|
||||
continue
|
||||
else:
|
||||
ctx_token = current_handler.set(handler)
|
||||
try:
|
||||
if self.middleware_key:
|
||||
# context.set_value('handler', handler)
|
||||
await self.dispatcher.middleware.trigger(f"process_{self.middleware_key}", args + (data,))
|
||||
partial_data = _check_spec(handler, data)
|
||||
response = await handler(*args, **partial_data)
|
||||
|
|
@ -101,6 +102,8 @@ class Handler:
|
|||
continue
|
||||
except CancelHandler:
|
||||
break
|
||||
finally:
|
||||
current_handler.reset(ctx_token)
|
||||
finally:
|
||||
if self.middleware_key:
|
||||
await self.dispatcher.middleware.trigger(f"post_process_{self.middleware_key}",
|
||||
|
|
|
|||
|
|
@ -3,8 +3,9 @@ import asyncio
|
|||
from aiogram import Bot, Dispatcher, executor, types
|
||||
from aiogram.contrib.fsm_storage.redis import RedisStorage2
|
||||
from aiogram.dispatcher import DEFAULT_RATE_LIMIT
|
||||
from aiogram.dispatcher.handler import CancelHandler
|
||||
from aiogram.dispatcher.handler import CancelHandler, current_handler
|
||||
from aiogram.dispatcher.middlewares import BaseMiddleware
|
||||
from aiogram.utils.exceptions import Throttled
|
||||
|
||||
TOKEN = 'BOT TOKEN HERE'
|
||||
|
||||
|
|
@ -52,11 +53,10 @@ class ThrottlingMiddleware(BaseMiddleware):
|
|||
:param message:
|
||||
"""
|
||||
# Get current handler
|
||||
# handler = context.get_value('handler')
|
||||
handler = current_handler.get()
|
||||
|
||||
# Get dispatcher from context
|
||||
dispatcher = Dispatcher.current()
|
||||
|
||||
# If handler was configured, get rate limit and key from handler
|
||||
if handler:
|
||||
limit = getattr(handler, 'throttling_rate_limit', self.rate_limit)
|
||||
|
|
@ -82,7 +82,7 @@ class ThrottlingMiddleware(BaseMiddleware):
|
|||
:param message:
|
||||
:param throttled:
|
||||
"""
|
||||
# handler = context.get_value('handler')
|
||||
handler = current_handler.get()
|
||||
dispatcher = Dispatcher.current()
|
||||
if handler:
|
||||
key = getattr(handler, 'throttling_key', f"{self.prefix}_{handler.__name__}")
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue