Module slack_bolt.middleware.async_custom_middleware
Expand source code
import inspect
from logging import Logger
from typing import Callable, Awaitable, Any, Sequence
from slack_bolt.kwargs_injection.async_utils import build_async_required_kwargs
from slack_bolt.logger import get_bolt_app_logger
from slack_bolt.request.async_request import AsyncBoltRequest
from slack_bolt.response import BoltResponse
from .async_middleware import AsyncMiddleware
from slack_bolt.util.utils import get_name_for_callable
class AsyncCustomMiddleware(AsyncMiddleware):
app_name: str
func: Callable[..., Awaitable[Any]]
arg_names: Sequence[str]
logger: Logger
def __init__(self, *, app_name: str, func: Callable[..., Awaitable[Any]]):
self.app_name = app_name
if inspect.iscoroutinefunction(func):
self.func = func
else:
raise ValueError("Async middleware function must be an async function")
self.arg_names = inspect.getfullargspec(func).args
self.logger = get_bolt_app_logger(self.app_name, self.func)
async def async_process(
self,
*,
req: AsyncBoltRequest,
resp: BoltResponse,
next: Callable[[], Awaitable[BoltResponse]],
) -> BoltResponse:
return await self.func(
**build_async_required_kwargs(
logger=self.logger,
required_arg_names=self.arg_names,
request=req,
response=resp,
next_func=next,
this_func=self.func,
)
)
@property
def name(self) -> str:
return f"AsyncCustomMiddleware(func={get_name_for_callable(self.func)})"
Classes
class AsyncCustomMiddleware (*, app_name: str, func: Callable[..., Awaitable[Any]])
-
A middleware can process request data before other middleware and listener functions.
Expand source code
class AsyncCustomMiddleware(AsyncMiddleware): app_name: str func: Callable[..., Awaitable[Any]] arg_names: Sequence[str] logger: Logger def __init__(self, *, app_name: str, func: Callable[..., Awaitable[Any]]): self.app_name = app_name if inspect.iscoroutinefunction(func): self.func = func else: raise ValueError("Async middleware function must be an async function") self.arg_names = inspect.getfullargspec(func).args self.logger = get_bolt_app_logger(self.app_name, self.func) async def async_process( self, *, req: AsyncBoltRequest, resp: BoltResponse, next: Callable[[], Awaitable[BoltResponse]], ) -> BoltResponse: return await self.func( **build_async_required_kwargs( logger=self.logger, required_arg_names=self.arg_names, request=req, response=resp, next_func=next, this_func=self.func, ) ) @property def name(self) -> str: return f"AsyncCustomMiddleware(func={get_name_for_callable(self.func)})"
Ancestors
Class variables
var app_name : str
var arg_names : Sequence[str]
var func : Callable[..., Awaitable[Any]]
var logger : logging.Logger
Inherited members