Module slack_bolt.adapter.wsgi.handler

Classes

class SlackRequestHandler (app: App,
path: str = '/slack/events')
Expand source code
class SlackRequestHandler:
    def __init__(self, app: App, path: str = "/slack/events"):
        """Setup Bolt as a WSGI web framework, this will make your application compatible with WSGI web servers.
        This can be used for production deployments.

        With the default settings, `http://localhost:3000/slack/events`
        Run Bolt with [gunicorn](https://gunicorn.org/)

        # Python
            app = App()

            api = SlackRequestHandler(app)

        # bash
            export SLACK_SIGNING_SECRET=***

            export SLACK_BOT_TOKEN=xoxb-***

            gunicorn app:api -b 0.0.0.0:3000 --log-level debug

        Args:
            app: Your bolt application
            path: The path to handle request from Slack (Default: `/slack/events`)
        """
        self.path = path
        self.app = app

    def dispatch(self, request: WsgiHttpRequest) -> BoltResponse:
        return self.app.dispatch(
            BoltRequest(body=request.get_body(), query=request.query_string, headers=request.get_headers())
        )

    def handle_installation(self, request: WsgiHttpRequest) -> BoltResponse:
        return self.app.oauth_flow.handle_installation(  # type: ignore[union-attr]
            BoltRequest(body=request.get_body(), query=request.query_string, headers=request.get_headers())
        )

    def handle_callback(self, request: WsgiHttpRequest) -> BoltResponse:
        return self.app.oauth_flow.handle_callback(  # type: ignore[union-attr]
            BoltRequest(body=request.get_body(), query=request.query_string, headers=request.get_headers())
        )

    def _get_http_response(self, request: WsgiHttpRequest) -> WsgiHttpResponse:
        if request.method == "GET":
            if self.app.oauth_flow is not None:
                if request.path == self.app.oauth_flow.install_path:
                    bolt_response = self.handle_installation(request)
                    return WsgiHttpResponse(
                        status=bolt_response.status, headers=bolt_response.headers, body=bolt_response.body
                    )
                elif request.path == self.app.oauth_flow.redirect_uri_path:
                    bolt_response = self.handle_callback(request)
                    return WsgiHttpResponse(
                        status=bolt_response.status, headers=bolt_response.headers, body=bolt_response.body
                    )
        if request.method == "POST" and request.path == self.path:
            bolt_response = self.dispatch(request)
            return WsgiHttpResponse(status=bolt_response.status, headers=bolt_response.headers, body=bolt_response.body)
        return WsgiHttpResponse(status=404, headers={"content-type": ["text/plain;charset=utf-8"]}, body="Not Found")

    def __call__(
        self,
        environ: Dict[str, Any],
        start_response: Callable[[str, List[Tuple[str, str]]], None],
    ) -> Iterable[bytes]:
        request = WsgiHttpRequest(environ)
        if "HTTP" in request.protocol:
            response: WsgiHttpResponse = self._get_http_response(
                request=request,
            )
            start_response(response.status, response.get_headers())
            return response.get_body()
        raise TypeError(f"Unsupported SERVER_PROTOCOL: {request.protocol}")

Setup Bolt as a WSGI web framework, this will make your application compatible with WSGI web servers. This can be used for production deployments.

With the default settings, http://localhost:3000/slack/events Run Bolt with gunicorn

Python

app = App()

api = SlackRequestHandler(app)

bash

export SLACK_SIGNING_SECRET=***

export SLACK_BOT_TOKEN=xoxb-***

gunicorn app:api -b 0.0.0.0:3000 --log-level debug

Args

app
Your bolt application
path
The path to handle request from Slack (Default: /slack/events)

Methods

def dispatch(self,
request: WsgiHttpRequest) ‑> BoltResponse
Expand source code
def dispatch(self, request: WsgiHttpRequest) -> BoltResponse:
    return self.app.dispatch(
        BoltRequest(body=request.get_body(), query=request.query_string, headers=request.get_headers())
    )
def handle_callback(self,
request: WsgiHttpRequest) ‑> BoltResponse
Expand source code
def handle_callback(self, request: WsgiHttpRequest) -> BoltResponse:
    return self.app.oauth_flow.handle_callback(  # type: ignore[union-attr]
        BoltRequest(body=request.get_body(), query=request.query_string, headers=request.get_headers())
    )
def handle_installation(self,
request: WsgiHttpRequest) ‑> BoltResponse
Expand source code
def handle_installation(self, request: WsgiHttpRequest) -> BoltResponse:
    return self.app.oauth_flow.handle_installation(  # type: ignore[union-attr]
        BoltRequest(body=request.get_body(), query=request.query_string, headers=request.get_headers())
    )