Loading...
Loading...
Use this skill when building real-time, bidirectional streaming applications with the Gemini Live API. Covers WebSocket-based audio/video/text streaming, voice activity detection (VAD), native audio features, function calling, session management, ephemeral tokens for client-side auth, and all Live API configuration options. SDKs covered - google-genai (Python), @google/genai (JavaScript/TypeScript).
npx skill4agent add google-gemini/gemini-skills gemini-live-api-dev[!NOTE] The Live API currently only supports WebSockets. For WebRTC support or simplified integration, use a partner integration.
gemini-2.5-flash-native-audio-preview-12-2025[!WARNING] The following Live API models are deprecated and will be shut down. Migrate to.gemini-2.5-flash-native-audio-preview-12-2025
— Released June 17, 2025. Shutdown: December 9, 2025.gemini-live-2.5-flash-preview — Released April 9, 2025. Shutdown: December 9, 2025.gemini-2.0-flash-live-001
google-genaipip install google-genai@google/genainpm install @google/genai[!WARNING] Legacy SDKs(Python) andgoogle-generativeai(JS) are deprecated. Use the new SDKs above.@google/generative-ai
audio/pcm;rate=16000[!IMPORTANT] Use/send_realtime_inputfor all real-time user input (audio, video, and text). UsesendRealtimeInput/send_client_contentonly for incremental conversation history updates (appending prior turns to context), not for sending new user messages.sendClientContent
[!WARNING] Do not useinmedia. Use the specific keys:sendRealtimeInputfor audio data,audiofor images/video frames, andvideofor text input.text
from google import genai
client = genai.Client(api_key="YOUR_API_KEY")import { GoogleGenAI } from '@google/genai';
const ai = new GoogleGenAI({ apiKey: 'YOUR_API_KEY' });from google.genai import types
config = types.LiveConnectConfig(
response_modalities=[types.Modality.AUDIO],
system_instruction=types.Content(
parts=[types.Part(text="You are a helpful assistant.")]
)
)
async with client.aio.live.connect(model="gemini-2.5-flash-native-audio-preview-12-2025", config=config) as session:
pass # Session is now activeconst session = await ai.live.connect({
model: 'gemini-2.5-flash-native-audio-preview-12-2025',
config: {
responseModalities: ['audio'],
systemInstruction: { parts: [{ text: 'You are a helpful assistant.' }] }
},
callbacks: {
onopen: () => console.log('Connected'),
onmessage: (response) => console.log('Message:', response),
onerror: (error) => console.error('Error:', error),
onclose: () => console.log('Closed')
}
});await session.send_realtime_input(text="Hello, how are you?")session.sendRealtimeInput({ text: 'Hello, how are you?' });await session.send_realtime_input(
audio=types.Blob(data=chunk, mime_type="audio/pcm;rate=16000")
)session.sendRealtimeInput({
audio: { data: chunk.toString('base64'), mimeType: 'audio/pcm;rate=16000' }
});# frame: raw JPEG-encoded bytes
await session.send_realtime_input(
video=types.Blob(data=frame, mime_type="image/jpeg")
)session.sendRealtimeInput({
video: { data: frame.toString('base64'), mimeType: 'image/jpeg' }
});async for response in session.receive():
content = response.server_content
if content:
# Audio
if content.model_turn:
for part in content.model_turn.parts:
if part.inline_data:
audio_data = part.inline_data.data
# Transcription
if content.input_transcription:
print(f"User: {content.input_transcription.text}")
if content.output_transcription:
print(f"Gemini: {content.output_transcription.text}")
# Interruption
if content.interrupted is True:
pass # Stop playback, clear audio queue// Inside the onmessage callback
const content = response.serverContent;
if (content?.modelTurn?.parts) {
for (const part of content.modelTurn.parts) {
if (part.inlineData) {
const audioData = part.inlineData.data; // Base64 encoded
}
}
}
if (content?.inputTranscription) console.log('User:', content.inputTranscription.text);
if (content?.outputTranscription) console.log('Gemini:', content.outputTranscription.text);
if (content?.interrupted) { /* Stop playback, clear audio queue */ }TEXTAUDIOsend_realtime_inputsend_client_contentaudioStreamEndhttps://ai.google.dev/gemini-api/docs/llms.txt.md.txtllms.txthttps://ai.google.dev/gemini-api/docs/live-session.md.txt[!IMPORTANT] Those are not all the documentation pages. Use theindex to discover available documentation pagesllms.txt