Meta Events ↗
noOriginal Documentation
Documentation Index#
Fetch the complete documentation index at: https://docs.ag-ui.com/llms.txt Use this file to discover all available pages before exploring further.
Annotations and signals independent of agent runs
Meta Events Proposal#
Summary#
Problem Statement#
Currently, AG-UI events are tightly coupled to agent runs. There’s no standardized way to attach user feedback, annotations, or external signals to the event stream that are independent of the agent’s execution lifecycle.
Motivation#
AG-UI is extended with MetaEvents, a new class of events that can occur at any point in the event stream, independent of agent runs. MetaEvents provide a way to attach annotations, signals, or feedback to a serialized stream. They may originate from users, clients, or external systems rather than from agents. Examples include reactions such as thumbs up/down on a message.
Status#
- Status: Draft
- Author(s): Markus Ecker (mail@mme.xyz)
Detailed Specification#
Overview#
This proposal introduces:
- A new MetaEvent type for side-band annotations
- Events that can appear anywhere in the stream
- Support for user feedback, tags, and external annotations
- Extensible payload structure for application-specific data
New Type: MetaEvent#
type MetaEvent = BaseEvent & {
type: EventType.META
/**
* Application-defined type of the meta event.
* Examples: "thumbs_up", "thumbs_down", "tag", "note"
*/
metaType: string
/**
* Application-defined payload.
* May reference other entities (e.g., messageId) or contain freeform data.
*/
payload: Record<string, unknown>
}Key Characteristics#
- Run-independent: MetaEvents are not tied to any specific run lifecycle
- Position-flexible: Can appear before, between, or after runs
- Origin-diverse: May come from users, clients, or external systems
- Extensible: Applications define their own metaType values and payload schemas
Implementation Examples#
User Feedback#
Thumbs Up:
{
"id": "evt_123",
"ts": 1714063982000,
"type": "META",
"metaType": "thumbs_up",
"payload": {
"messageId": "msg_456",
"userId": "user_789"
}
}Thumbs Down with Reason:
{
"id": "evt_124",
"ts": 1714063985000,
"type": "META",
"metaType": "thumbs_down",
"payload": {
"messageId": "msg_456",
"userId": "user_789",
"reason": "inaccurate",
"comment": "The calculation seems incorrect"
}
}Annotations#
User Note:
{
"id": "evt_789",
"ts": 1714064001000,
"type": "META",
"metaType": "note",
"payload": {
"text": "Important question to revisit",
"relatedRunId": "run_001",
"author": "user_123"
}
}Tag Assignment:
{
"id": "evt_890",
"ts": 1714064100000,
"type": "META",
"metaType": "tag",
"payload": {
"tags": ["important", "follow-up"],
"threadId": "thread_001"
}
}External System Events#
Analytics Event:
{
"id": "evt_901",
"ts": 1714064200000,
"type": "META",
"metaType": "analytics",
"payload": {
"event": "conversation_shared",
"properties": {
"shareMethod": "link",
"recipientCount": 3
}
}
}Moderation Flag:
{
"id": "evt_902",
"ts": 1714064300000,
"type": "META",
"metaType": "moderation",
"payload": {
"action": "flag",
"messageId": "msg_999",
"category": "inappropriate_content",
"confidence": 0.95
}
}Common Meta Event Types#
While applications can define their own types, these are commonly used:
| MetaType | Description | Typical Payload |
|---|---|---|
thumbs_up | Positive feedback | { messageId, userId } |
thumbs_down | Negative feedback | { messageId, userId, reason? } |
note | User annotation | { text, relatedId?, author } |
tag | Categorization | { tags[], targetId } |
bookmark | Save for later | { messageId, userId } |
copy | Content copied | { messageId, content } |
share | Content shared | { messageId, method } |
rating | Numeric rating | { messageId, rating, maxRating } |
Use Cases#
User Feedback Collection#
Capture user reactions to agent responses for quality improvement.
Conversation Annotation#
Allow users to add notes, tags, or bookmarks to important parts of conversations.
Analytics and Tracking#
Record user interactions and behaviors without affecting agent execution.
Content Moderation#
Flag or mark content for review by external moderation systems.
Collaborative Features#
Enable multiple users to annotate or comment on shared conversations.
Audit Trail#
Create a complete record of all interactions, not just agent responses.
Implementation Considerations#
Client SDK Changes#
TypeScript SDK:
- New
MetaEventtype in@ag-ui/core - Helper functions for common meta event types
- MetaEvent filtering and querying utilities
Python SDK:
MetaEventclass implementation- Meta event builders for common types
- Event stream filtering capabilities
Testing Strategy#
- Unit tests for MetaEvent creation and validation
- Integration tests with mixed event streams
- Performance tests with high-volume meta events
- Security tests for payload validation