Handlers and context
Event handlers and the context object your agent code receives on every turn.
Novu gives your handler the same building blocks whether the message came from Slack, email, or another provider, and whether you call an LLM or plain TypeScript.
Event handlers
Event handlers are functions that respond to events in a conversation. Your agent can respond to four event types:
| Handler | When it runs | Common use case |
|---|---|---|
onMessage | A user sends a message in the conversation | Process the message and reply |
onAction | A user clicks a button or selects a value in an interactive card | Handle form submissions, button clicks, dropdown selections |
onReaction | A user adds or removes a reaction | Capture feedback or trigger a follow-up |
onResolve | The conversation is marked as resolved | Clean up state, log analytics, or send a summary |
Handlers are where the communication layer connects to your application logic. For example, an onMessage handler receives the user's message, passes conversation context to an LLM or custom function, and sends the response back through Novu.
Context object
Each event handler receives a context object with the information needed to understand the current event and respond. Depending on the event type, it can include:
- The incoming message
- The current conversation state and metadata
- The resolved subscriber (when available)
- Recent conversation history
- Provider information
- Platform-specific details, such as thread or channel identifiers
- Methods for replying, updating metadata, triggering workflows, or resolving the conversation
The context object is how your code talks to Novu. You do not call Slack, Teams, or email APIs directly in the handler.
Event handling flow
When a user messages your agent:
- A user sends a message from a connected provider (for example, Slack).
- Novu receives the event through the provider connection.
- Novu maps the provider thread to a conversation and resolves the platform user to a subscriber, when possible.
- Novu calls the agent's
onMessagehandler with the context object. - Your handler passes the message and conversation context to your agent logic.
- Your agent logic decides what should happen next.
- Your handler sends a reply, emits signals, or both.
- Novu delivers the reply back to the provider thread.
- Novu records messages, participants, metadata, signals, and conversation status.
The same agent logic works across all connected providers because Novu handles the provider-specific communication layer. Connecting a new provider does not require changing your agent code.
onMessage
onMessage fires every time a user sends a message in a conversation with your agent.
Handling attachments
Inbound messages can include file attachments when the platform supports them. Novu normalizes files into message.attachments with short-lived signed URLs. Keep in mind:
- Download attachment URLs promptly inside your handler.
- Signed links are valid for 15 minutes.
- Inbound attachments are limited to 25 MB per file.
onAction
onAction fires when a user clicks a button or selects a value in an interactive card. See Interactive cards.
onReaction
onReaction fires when a user adds or removes an emoji reaction on a message.
onResolve
onResolve fires when the conversation is marked as resolved via ctx.resolve() or the resolve signal.