gemini-media-mcp
Provides AI media generation capabilities via Google Gemini API, including image generation/editing, video creation with Veo models, text-to-speech, and music generation with Lyria.
gemini-media-mcp
Unified Go MCP server for AI media generation via Google Gemini API and Vertex AI.
Features
Image generation -- text-to-image with configurable aspect ratios and resolutions (1K/2K/4K)
Image editing -- modify existing images with natural language prompts
Multi-reference composition -- combine up to 3 reference images with style/content guidance
Video generation -- text-to-video via Veo 3.1 Lite, Fast, and Standard tiers
Image-to-video -- animate still images into video clips
Video extension -- chain clips for longer content (Fast and Standard tiers)
Text-to-speech -- generate spoken audio with configurable voices and languages
Music generation -- AI music via Lyria 3 (30s clips or full songs with vocals, structure control)
Single binary -- no runtime dependencies, runs over stdio transport
Provider abstraction -- backend-agnostic interfaces for image, video, audio, and model operations
Dual backend -- supports both Gemini API (API key) and Vertex AI (project credentials)
Quick Start
# Install
go install github.com/mordor-forge/gemini-media-mcp/cmd/gemini-media-mcp@latest
# Configure (Gemini API; either variable name works)
export GEMINI_API_KEY="your-api-key"
# export GOOGLE_API_KEY="your-api-key"
# Or configure (Vertex AI)
export GOOGLE_CLOUD_PROJECT="your-project-id"
export GOOGLE_CLOUD_LOCATION="us-central1"
# Run directly (stdio transport)
gemini-media-mcpThen add it to your MCP client -- see MCP Client Configuration below.
Configuration
Variable | Required | Default | Description |
| Yes* | -- | Gemini API key. |
| Yes* | -- | GCP project ID for Vertex AI backend |
| No |
| GCP region for Vertex AI |
| No |
| Directory for saved media files |
*One of GOOGLE_API_KEY or GOOGLE_CLOUD_PROJECT must be set. If both are set, API key takes precedence (avoids conflicts when GOOGLE_CLOUD_PROJECT is set in the shell for other tools).
If you're unsure which backend is active, call get_config from your MCP client to confirm the selected backend and output directory.
Available Tools
Tool | Description | Type |
| Generate image from text prompt | Sync |
| Edit existing image with text prompt | Sync |
| Multi-reference image composition (up to 3) | Sync |
| Generate video from text prompt (returns operation ID) | Async |
| Animate image into video (first frame) | Async |
| Chain video clips for longer content | Async |
| Check video generation progress | Sync |
| Download completed video | Sync |
| Generate spoken audio from text (TTS) | Sync |
| Generate AI music from text description (Lyria) | Sync |
| Show available models with capabilities and pricing | Sync |
| Show current backend and configuration | Sync |
Async tools return an operation ID immediately. Use video_status to poll for completion, then download_video to retrieve the file.
Model Tiers
Image
Tier | Model | Best For | Cost |
nb2 (default) |
| Quick iterations, most tasks | ~$0.067/img |
pro |
| Final renders, complex scenes | ~$0.134/img |
Both tiers support resolutions 1K, 2K, 4K and aspect ratios 1:1, 2:3, 3:2, 3:4, 4:3, 4:5, 5:4, 9:16, 16:9, 21:9.
Video
Tier | Model | Best For | Cost |
lite (default) |
| High-volume, drafts | $0.05/sec (720p), $0.08/sec (1080p) |
fast |
| Good quality iterations | $0.15/sec (720p/1080p), $0.35/sec (4k) |
standard |
| Final renders, 4K | $0.40/sec (720p/1080p), $0.60/sec (4k) |
Supported aspect ratios are 16:9 and 9:16. Supported durations are 4, 6, and 8 seconds. Lite supports 720p and 1080p. Fast and Standard support 720p, 1080p, and 4K. Video extension (extend_video) is only available on Fast and Standard tiers, and the extension tier must match the original generation.
Audio (TTS)
Tier | Model | Best For | Cost |
tts |
| Text-to-speech with natural voices | Standard Gemini token pricing |
The generate_audio tool converts text to spoken audio. It supports:
Voice selection -- Choose from prebuilt voices like
Aoede,Kore,Puck, and more. Default:AoedeLanguage -- Set the language code (e.g.,
en-US,it-IT,cs-CZ,de-DE). Default:en-USNatural speech -- Generates expressive, natural-sounding speech with appropriate pacing and intonation
Output is saved as raw PCM audio (audio/L16, 24kHz sample rate). The file can be played with tools like ffplay or converted to other formats:
# Play directly
ffplay -f s16le -ar 24000 -ac 1 ~/generated_media/audio-2026-04-02T12-20-12-0603.pcm
# Convert to WAV
ffmpeg -f s16le -ar 24000 -ac 1 -i audio.pcm audio.wav
# Convert to MP3
ffmpeg -f s16le -ar 24000 -ac 1 -i audio.pcm audio.mp3Music (Lyria)
Tier | Model | Output | Best For | Cost |
clip (default) |
| 30-second clips | Quick iterations, sound design | ~$0.08/song |
full |
| Up to ~3 minutes | Full songs with vocals, verses, choruses | Token-based |
The generate_music tool creates AI-generated music from text descriptions. Capabilities include:
Genre and style -- specify any genre, instruments, BPM, key/scale, mood
Structure control -- use tags like
[Verse],[Chorus],[Bridge],[Intro],[Outro]Custom lyrics -- include lyrics with section markers for vocal tracks
Timestamp control --
[0:00 - 0:10] Intro: gentle piano...for precise section timingMulti-language -- prompt language determines output language
High fidelity -- 48kHz stereo MP3 output
All generated music is watermarked with SynthID.
Example prompts:
# Instrumental
"A gentle acoustic guitar melody in C major, 90 BPM, calm and peaceful indie folk"
# With structure
"[Intro] Ambient synth pad, ethereal
[Verse] Lo-fi hip-hop beat, mellow piano chords, vinyl crackle
[Chorus] Uplifting, add strings and gentle drums
[Outro] Fade out with reverb"
# With lyrics
"Upbeat pop song, 120 BPM, major key
[Chorus] We're dancing in the light / Everything feels right / Under stars so bright tonight"You can pass the tier name (lite, fast, standard, nb2, pro, tts, clip, full) or a raw model ID directly.
MCP Client Configuration
Claude Code
Add to your Claude Code MCP settings (~/.claude/settings.json or project .mcp.json):
{
"mcpServers": {
"gemini-media": {
"command": "gemini-media-mcp",
"env": {
"GOOGLE_API_KEY": "your-api-key",
"MEDIA_OUTPUT_DIR": "/path/to/output"
}
}
}
}Use either GOOGLE_API_KEY or GEMINI_API_KEY in the env block above; both are accepted.
Or if building from source:
{
"mcpServers": {
"gemini-media": {
"command": "/path/to/gemini-media-mcp",
"env": {
"GOOGLE_API_KEY": "your-api-key"
}
}
}
}Companion Skills for Claude Code
The skills/ directory contains Claude Code skills that provide interactive workflows on top of the MCP tools. Each skill guides Claude through prompt engineering, model selection, and iterative refinement for a specific media type.
Skill | Directory | Description |
gemini-image-gen |
| Image generation, editing, and multi-reference composition |
video-gen |
| Video generation with async polling, image-to-video, extension |
music-gen |
| Music generation with structure tags, lyrics, genre control |
tts-gen |
| Text-to-speech with voice and language selection |
To install a skill, copy its directory to ~/.claude/skills/:
cp -r skills/video-gen ~/.claude/skills/
cp -r skills/music-gen ~/.claude/skills/
cp -r skills/tts-gen ~/.claude/skills/
cp -r skills/gemini-image-gen ~/.claude/skills/Skills are optional — the MCP tools work without them. But the skills add prompt engineering guidance, model tier recommendations, and interactive review workflows that significantly improve output quality.
Building from Source
git clone https://github.com/mordor-forge/gemini-media-mcp.git
cd gemini-media-mcp
go build ./cmd/gemini-media-mcp/The binary will be created at ./gemini-media-mcp.
To run tests:
go test ./...Contributing
Fork the repository
Create a feature branch (
git checkout -b feature/your-feature)Make your changes and add tests
Run
go test ./...andgo vet ./...Commit your changes
Open a pull request against
main
License
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/mordor-forge/gemini-media-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server