Module slack_bolt.middleware.middleware
Classes
class Middleware
-
Expand source code
class Middleware(metaclass=ABCMeta): """A middleware can process request data before other middleware and listener functions.""" @abstractmethod def process( self, *, req: BoltRequest, resp: BoltResponse, # As this method is not supposed to be invoked by bolt-python users, # the naming conflict with the built-in one affects # only the internals of this method next: Callable[[], BoltResponse], ) -> Optional[BoltResponse]: """Processes a request data before other middleware and listeners. A middleware calls `next()` function if the chain should continue. @app.middleware def simple_middleware(req, resp, next): # do something here next() This `process(req, resp, next)` method is supposed to be invoked only inside bolt-python. If you want to avoid the name `next()` in your middleware functions, you can use `next_()` method instead. @app.middleware def simple_middleware(req, resp, next_): # do something here next_() Args: req: The incoming request resp: The response next: The function to tell the chain that it can continue Returns: Processed response (optional) """ raise NotImplementedError() @property def name(self) -> str: """The name of this middleware""" return f"{self.__module__}.{self.__class__.__name__}"
A middleware can process request data before other middleware and listener functions.
Subclasses
- Assistant
- AttachingFunctionToken
- Authorization
- CustomMiddleware
- IgnoringSelfEvents
- MessageListenerMatches
- RequestVerification
- SslCheck
- UrlVerification
- WorkflowStepMiddleware
Instance variables
prop name : str
-
Expand source code
@property def name(self) -> str: """The name of this middleware""" return f"{self.__module__}.{self.__class__.__name__}"
The name of this middleware
Methods
def process(self,
*,
req: BoltRequest,
resp: BoltResponse,
next: Callable[[], BoltResponse]) ‑> BoltResponse | None-
Expand source code
@abstractmethod def process( self, *, req: BoltRequest, resp: BoltResponse, # As this method is not supposed to be invoked by bolt-python users, # the naming conflict with the built-in one affects # only the internals of this method next: Callable[[], BoltResponse], ) -> Optional[BoltResponse]: """Processes a request data before other middleware and listeners. A middleware calls `next()` function if the chain should continue. @app.middleware def simple_middleware(req, resp, next): # do something here next() This `process(req, resp, next)` method is supposed to be invoked only inside bolt-python. If you want to avoid the name `next()` in your middleware functions, you can use `next_()` method instead. @app.middleware def simple_middleware(req, resp, next_): # do something here next_() Args: req: The incoming request resp: The response next: The function to tell the chain that it can continue Returns: Processed response (optional) """ raise NotImplementedError()
Processes a request data before other middleware and listeners. A middleware calls
next()
function if the chain should continue.@app.middleware def simple_middleware(req, resp, next): # do something here next()
This
process(req, resp, next)
method is supposed to be invoked only inside bolt-python. If you want to avoid the namenext()
in your middleware functions, you can usenext_()
method instead.@app.middleware def simple_middleware(req, resp, next_): # do something here next_()
Args
req
- The incoming request
resp
- The response
next
- The function to tell the chain that it can continue
Returns
Processed response (optional)