Expand description
Typed callback registry for Live session events.
Fast lane callbacks (sync, < 1ms): audio, text, transcripts, VAD. Control lane callbacks (async, can block): tool calls, lifecycle, interruptions. Outbound interceptors: transform tool responses, inject context at turn boundaries.
§Callback Modes
Each control-lane callback has an associated CallbackMode:
Blocking— awaited inline. The event loop waits for completion before processing the next event. Guarantees ordering and state consistency.Concurrent— spawned as a detached tokio task. The event loop continues immediately. Use for fire-and-forget work (logging, background agent dispatch, analytics).
Fast-lane callbacks (audio, text, VAD) are always sync and inline.
Interceptors (before_tool_response, on_turn_boundary) are always blocking.
Some control-lane callbacks are forced-blocking (no concurrent variant):
on_interrupted (must clear state before audio resumes),
on_tool_call (return value is the tool response).
Structs§
- Event
Callbacks - Typed callback registry for Live session events.
Enums§
- Callback
Mode - Controls how a control-lane callback is executed relative to the event loop.
Type Aliases§
- Async
Callback - Control-lane async callback with no payload.
- Async
Callback With - Control-lane async callback over one payload value.
- Async
Callback With2 - Control-lane async callback over two payload values.
- Audio
Callback - Fast-lane sync callback over a raw audio chunk.
- Before
Tool Response Callback - Middleware over outgoing tool responses (inspect/rewrite before send).
- Instruction
Fn - Sync state-reactive instruction generator (
None= leave unchanged). - Phase
Callback - Fast-lane sync callback over a session phase change.
- Signal
Callback - Fast-lane sync callback with no payload (VAD start/end).
- Text
Callback - Fast-lane sync callback over a text payload (delta, accumulated text, thought).
- Tool
Call Callback - Tool-call override: return
Some(responses)to reply,Noneto defer to auto-dispatch via the registeredToolDispatcher. - Transcript
Callback - Fast-lane sync callback over a transcript chunk with its
is_finalflag. - Usage
Callback - Fast-lane sync callback over usage metadata.