Skip to content

strands.experimental.bidi.models.gemini_live

Gemini Live API bidirectional model provider using official Google GenAI SDK.

Implements the BidiModel interface for Google’s Gemini Live API using the official Google GenAI SDK for simplified and robust WebSocket communication.

Key improvements over custom WebSocket implementation:

  • Uses official google-genai SDK with native Live API support
  • Simplified session management with client.aio.live.connect()
  • Built-in tool integration and event handling
  • Automatic WebSocket connection management and error handling
  • Native support for audio/text streaming and interruption
class BidiGeminiLiveModel(BidiModel)

Defined in: src/strands/experimental/bidi/models/gemini_live.py:54

Gemini Live API implementation using official Google GenAI SDK.

Combines model configuration and connection state in a single class. Provides a clean interface to Gemini Live API using the official SDK, eliminating custom WebSocket handling and providing robust error handling.

def __init__(model_id: str = "gemini-2.5-flash-native-audio-preview-09-2025",
provider_config: dict[str, Any] | None = None,
client_config: dict[str, Any] | None = None,
**kwargs: Any)

Defined in: src/strands/experimental/bidi/models/gemini_live.py:62

Initialize Gemini Live API bidirectional model.

Arguments:

  • model_id - Model identifier (default: gemini-2.5-flash-native-audio-preview-09-2025)
  • provider_config - Model behavior (audio, inference)
  • client_config - Authentication (api_key, http_options)
  • **kwargs - Reserved for future parameters.
async def start(system_prompt: str | None = None,
tools: list[ToolSpec] | None = None,
messages: Messages | None = None,
**kwargs: Any) -> None

Defined in: src/strands/experimental/bidi/models/gemini_live.py:135

Establish bidirectional connection with Gemini Live API.

Arguments:

  • system_prompt - System instructions for the model.
  • tools - List of tools available to the model.
  • messages - Conversation history to initialize with.
  • **kwargs - Additional configuration options.
async def receive() -> AsyncGenerator[BidiOutputEvent, None]

Defined in: src/strands/experimental/bidi/models/gemini_live.py:192

Receive Gemini Live API events and convert to provider-agnostic format.

async def send(content: BidiInputEvent | ToolResultEvent) -> None

Defined in: src/strands/experimental/bidi/models/gemini_live.py:373

Unified send method for all content types. Sends the given inputs to Google Live API.

Dispatches to appropriate internal handler based on content type.

Arguments:

  • content - Typed event (BidiTextInputEvent, BidiAudioInputEvent, BidiImageInputEvent, or ToolResultEvent).

Raises:

  • ValueError - If content type not supported (e.g., image content).
async def stop() -> None

Defined in: src/strands/experimental/bidi/models/gemini_live.py:470

Close Gemini Live API connection.