docs/reference/middleware/attaching_conversation_kwargs/index.html
slack_bolt.middleware.attaching_conversation_kwargs.async_attaching_conversation_kwargs
slack_bolt.middleware.attaching_conversation_kwargs.attaching_conversation_kwargs
class AttachingConversationKwargs (thread_context_store: AssistantThreadContextStore | None = None)#Expand source code
class AttachingConversationKwargs(Middleware):
thread_context_store: Optional[AssistantThreadContextStore]
def __init__ (self, thread_context_store: Optional[AssistantThreadContextStore] = None):
self.thread_context_store = thread_context_store
def process(self, *, req: BoltRequest, resp: BoltResponse, next: Callable[[], BoltResponse]) -> Optional[BoltResponse]:
event = to_event(req.body)
if event is not None:
if is_assistant_event(req.body):
assistant = AssistantUtilities(
payload=event,
context=req.context,
thread_context_store=self.thread_context_store,
)
req.context["say"] = assistant.say
req.context["set_title"] = assistant.set_title
req.context["set_suggested_prompts"] = assistant.set_suggested_prompts
req.context["get_thread_context"] = assistant.get_thread_context
req.context["save_thread_context"] = assistant.save_thread_context
# TODO: in the future we might want to introduce a "proper" extract_ts utility
thread_ts = req.context.thread_ts or event.get("ts")
if req.context.channel_id and thread_ts:
req.context["set_status"] = SetStatus(
client=req.context.client,
channel_id=req.context.channel_id,
thread_ts=thread_ts,
)
req.context["say_stream"] = SayStream(
client=req.context.client,
channel=req.context.channel_id,
recipient_team_id=req.context.team_id or req.context.enterprise_id,
recipient_user_id=req.context.user_id,
thread_ts=thread_ts,
)
return next()
A middleware can process request data before other middleware and listener functions.
var thread_context_store : AssistantThreadContextStore | None
The type of the None singleton.
Middleware:
nameprocess