AI Agents Overview
AI Agents enable intelligent, automated interactions within your application. They can process user messages, trigger tools, and respond with contextually relevant information. For a broader introduction, see the AI Agents section.Note: Currently, an Agent only responds to Text Messages.
Agent Run Lifecycle and Message Flow
This section explains how a user’s text message to an Agent becomes a structured “run” which emits real-time events and then produces agentic messages for historical retrieval.- A user sends a text message to an Agent.
- The platform starts a run and streams real-time events via the AIAssistantListener.
- After the run completes, persisted Agentic Messages arrive via the MessageListener.
Real-time Events
Events are received via theonAIAssistantEventReceived method of the AIAssistantListener class in this general order:
- Run Start
- Zero or more tool call cycles (repeats for each tool invocation):
- Tool Call Start
- Tool Call Arguments
- Tool Call End
- Tool Call Result
 
- One or more assistant reply streams:
- Text Message Start
- Text Message Content (multiple times; token/char streaming)
- Text Message End
 
- Run Finished
- Run Startand- Run Finishedare always emitted.
- Tool Callevents appear only when a backend or frontend tool is invoked. There can be multiple tool calls in a single run.
- Text Messageevents are always emitted and carry the assistant’s reply incrementally.
- JavaScript
- TypeScript
Event descriptions
- Run Start: A new run has begun for the user’s message.
- Tool Call Start: The agent decided to invoke a tool.
- Tool Call Arguments: Arguments being passed to the tool.
- Tool Call End: Tool execution completed.
- Tool Call Result: Tool’s output is available.
- Text Message Start: The agent started composing a reply.
- Text Message Content: Streaming content chunks for progressive rendering.
- Text Message End: The agent reply is complete.
- Run Finished: The run is finalized; persisted messages will follow.
Agentic Messages
These events are received via theMessageListener after the run completes.
- AIAssistantMessage: The full assistant reply.
- AIToolResultMessage: The final output of a tool call.
- AIToolArgumentMessage: The arguments that were passed to a tool.
- JavaScript
- TypeScript