Module slack_bolt.adapter.sanic.async_handler
Expand source code
from datetime import datetime
from sanic.request import Request
from sanic.response import HTTPResponse
from slack_bolt import BoltResponse
from slack_bolt.async_app import AsyncApp, AsyncBoltRequest
from slack_bolt.oauth.async_oauth_flow import AsyncOAuthFlow
def to_async_bolt_request(req: Request) -> AsyncBoltRequest:
return AsyncBoltRequest(
body=req.body.decode("utf-8"),
query=req.query_string,
headers=req.headers,
)
def to_sanic_response(bolt_resp: BoltResponse) -> HTTPResponse:
resp = HTTPResponse(
status=bolt_resp.status,
body=bolt_resp.body,
headers=bolt_resp.first_headers_without_set_cookie(),
)
for cookie in bolt_resp.cookies():
for name, c in cookie.items():
resp.cookies[name] = c.value
expire_value = c.get("expires")
if expire_value is not None and expire_value != "":
expire = datetime.strptime(expire_value, "%a, %d %b %Y %H:%M:%S %Z")
resp.cookies[name]["expires"] = expire
resp.cookies[name]["path"] = c.get("path")
resp.cookies[name]["domain"] = c.get("domain")
resp.cookies[name]["max-age"] = c.get("max-age")
resp.cookies[name]["secure"] = True
resp.cookies[name]["httponly"] = True
return resp
class AsyncSlackRequestHandler:
def __init__(self, app: AsyncApp): # type: ignore
self.app = app
async def handle(self, req: Request) -> HTTPResponse:
if req.method == "GET":
if self.app.oauth_flow is not None:
oauth_flow: AsyncOAuthFlow = self.app.oauth_flow
if req.path == oauth_flow.install_path:
bolt_resp = await oauth_flow.handle_installation(
to_async_bolt_request(req)
)
return to_sanic_response(bolt_resp)
elif req.path == oauth_flow.redirect_uri_path:
bolt_resp = await oauth_flow.handle_callback(
to_async_bolt_request(req)
)
return to_sanic_response(bolt_resp)
elif req.method == "POST":
bolt_resp = await self.app.async_dispatch(to_async_bolt_request(req))
return to_sanic_response(bolt_resp)
return HTTPResponse(
status=404,
body="Not found",
)
Functions
def to_async_bolt_request(req: sanic.request.Request) ‑> AsyncBoltRequest
-
Expand source code
def to_async_bolt_request(req: Request) -> AsyncBoltRequest: return AsyncBoltRequest( body=req.body.decode("utf-8"), query=req.query_string, headers=req.headers, )
def to_sanic_response(bolt_resp: BoltResponse) ‑> sanic.response.HTTPResponse
-
Expand source code
def to_sanic_response(bolt_resp: BoltResponse) -> HTTPResponse: resp = HTTPResponse( status=bolt_resp.status, body=bolt_resp.body, headers=bolt_resp.first_headers_without_set_cookie(), ) for cookie in bolt_resp.cookies(): for name, c in cookie.items(): resp.cookies[name] = c.value expire_value = c.get("expires") if expire_value is not None and expire_value != "": expire = datetime.strptime(expire_value, "%a, %d %b %Y %H:%M:%S %Z") resp.cookies[name]["expires"] = expire resp.cookies[name]["path"] = c.get("path") resp.cookies[name]["domain"] = c.get("domain") resp.cookies[name]["max-age"] = c.get("max-age") resp.cookies[name]["secure"] = True resp.cookies[name]["httponly"] = True return resp
Classes
class AsyncSlackRequestHandler (app: AsyncApp)
-
Expand source code
class AsyncSlackRequestHandler: def __init__(self, app: AsyncApp): # type: ignore self.app = app async def handle(self, req: Request) -> HTTPResponse: if req.method == "GET": if self.app.oauth_flow is not None: oauth_flow: AsyncOAuthFlow = self.app.oauth_flow if req.path == oauth_flow.install_path: bolt_resp = await oauth_flow.handle_installation( to_async_bolt_request(req) ) return to_sanic_response(bolt_resp) elif req.path == oauth_flow.redirect_uri_path: bolt_resp = await oauth_flow.handle_callback( to_async_bolt_request(req) ) return to_sanic_response(bolt_resp) elif req.method == "POST": bolt_resp = await self.app.async_dispatch(to_async_bolt_request(req)) return to_sanic_response(bolt_resp) return HTTPResponse( status=404, body="Not found", )
Methods
async def handle(self, req: sanic.request.Request) ‑> sanic.response.HTTPResponse
-
Expand source code
async def handle(self, req: Request) -> HTTPResponse: if req.method == "GET": if self.app.oauth_flow is not None: oauth_flow: AsyncOAuthFlow = self.app.oauth_flow if req.path == oauth_flow.install_path: bolt_resp = await oauth_flow.handle_installation( to_async_bolt_request(req) ) return to_sanic_response(bolt_resp) elif req.path == oauth_flow.redirect_uri_path: bolt_resp = await oauth_flow.handle_callback( to_async_bolt_request(req) ) return to_sanic_response(bolt_resp) elif req.method == "POST": bolt_resp = await self.app.async_dispatch(to_async_bolt_request(req)) return to_sanic_response(bolt_resp) return HTTPResponse( status=404, body="Not found", )