nano-banana-mcp Server

A Model Context Protocol server for AI image generation and editing with Google's Gemini "Nano Banana" image models, via the Interactions API. Generate, edit, and iterate on images directly from Claude Code, Claude Desktop, Cursor, or any MCP-compatible client — with multi-turn editing, search grounding, interleaved storyboards, style-consistent icon sets, and image-from-video.

Documentation

nano-banana-mcp

CI License: MIT Node.js MCP

A Model Context Protocol server for AI image generation and editing with Google's Gemini "Nano Banana" image models, via the Interactions API.

Generate, edit, and iterate on images directly from Claude Code, Claude Desktop, Cursor, or any MCP-compatible client — with multi-turn editing, search grounding, interleaved storyboards, style-consistent icon sets, and image-from-video.

Photorealistic product shot of a teal ceramic coffee mug Isometric illustration of a developer workstation Kawaii banana sticker wearing sunglasses

All generated by this server — a photoreal product shot, an isometric illustration with legible text, and a vector sticker. No edits.

Note: This server uses the Gemini Interactions API, which is currently in beta. The Gemini 3 image models (gemini-3-pro-image, gemini-3.1-flash-image) may require access on your API key. The nano tier (gemini-2.5-flash-image) is the most widely available. See Requirements.

Features

  • Text-to-image — high-quality images from a prompt, up to 4K, with aspect-ratio and resolution control
  • Multi-turn editing — iterate conversationally; each result returns an interaction_id you pass back to keep editing
  • Reference images — up to 14 inputs for virtual try-on, product placement, compositing, style transfer, photo restoration, attribute replacement, 2D→3D mockups
  • Search grounding — ground images in real-time data (weather, news, scores) with Google Search and Google Image Search
  • Interleaved stories — one prompt → a sequence of captioned images (storyboards, comics, recipes, illustrated explainers)
  • Style-consistent icon sets — chained generation keeps a uniform look across an icon set
  • Image from video — generate thumbnails/posters from a public YouTube URL
  • Inline previews — downscaled previews returned to the client so the model can see what it generated and self-correct
  • Robust — automatic retries with backoff on rate limits and transient errors; clear, actionable error messages

Quick Start

1. Get a Gemini API key

Create a key at Google AI Studio.

2. Install

git clone https://github.com/petrkindlmann/nano-banana-mcp.git
cd nano-banana-mcp
npm install

3. Register with your MCP client

Claude Code

claude mcp add nano-banana --scope user \
  --env GEMINI_API_KEY=your_key_here \
  -- node /absolute/path/to/nano-banana-mcp/index.js

Claude Desktop / Cursor / Windsurf / VS Code

Add to your MCP config (e.g. ~/Library/Application Support/Claude/claude_desktop_config.json on macOS):

{
  "mcpServers": {
    "nano-banana": {
      "command": "node",
      "args": ["/absolute/path/to/nano-banana-mcp/index.js"],
      "env": {
        "GEMINI_API_KEY": "your_key_here"
      }
    }
  }
}

Restart your client. The five tools below will appear.

Configuration

Env varRequiredDescription
GEMINI_API_KEYYour Gemini API key.
NANO_BANANA_MODEL_NANOOverride the nano tier's model ID.
NANO_BANANA_MODEL_FLASHOverride the flash tier's model ID.
NANO_BANANA_MODEL_PROOverride the pro tier's model ID.

The model IDs are beta/preview models that Google rotates and occasionally retires. If a newer version ships — or a configured ID is deprecated — point a tier at a new model without editing code:

"env": {
  "GEMINI_API_KEY": "your_key_here",
  "NANO_BANANA_MODEL_FLASH": "gemini-3.2-flash-image"
}

Each tier keeps its capability profile (sizes, aspect ratios, grounding) regardless of the ID you assign it.

Usage

Just ask in natural language — your MCP client picks the right tool and arguments.

You: Generate a 16:9 hero image of a misty pine forest at dawn, cinematic, save it to hero.jpg

Claude: calls generate_image → saves hero.jpg, returns an interaction_id and a preview

You: Make the fog heavier and add a deer in the clearing

Claude: calls edit_image with the previous interaction_idhero-v2.jpg

Multi-turn editing is the recommended way to iterate: each result carries an interaction_id, and passing it back keeps the full conversation context so edits stay consistent.

Tools

ToolDescription
generate_imageGenerate a single image from a text prompt. Optional search grounding, thinking, and aspect/size control.
edit_imageEdit or iterate on an image — chain via previous_interaction_id, or pass reference images from disk.
generate_storyGenerate interleaved text + images from one prompt (storyboards, comics, recipes, explainers).
generate_icon_setGenerate a set of style-consistent icons via chained generation.
generate_from_videoGenerate an image from a public YouTube video URL (flash model only).

Models

TierModel IDSizesSearch groundingThinkingVideo inputJPEG output
nanogemini-2.5-flash-image1K— (PNG only)
flashgemini-3.1-flash-image0.5K, 1K, 2K, 4Kweb + image
progemini-3-pro-image1K, 2K, 4Kweb

Which should I use?

  • flash (default) — your go-to. Best all-around balance of quality, cost, and latency. Up to 4K, search grounding, the widest aspect ratios (21:9, 1:4, etc.), and the only tier that accepts video input.
  • pro — the highest-quality renderer. Use for professional/deliverable assets, complex multi-element instructions, and legible text rendered inside the image (infographics, posters, menus). A built-in "Thinking" pass refines composition before rendering. Slower and pricier.
  • nano — speed and volume. 1K-only, no grounding/thinking, always returns PNG. Reach for it when generating many images fast and per-image quality matters less.

generate_story defaults to pro (best interleaved quality); generate_from_video is locked to flash (the only tier that accepts video).

generate_image

ArgTypeDefaultNotes
promptstringRequired. What to generate.
outputstringRequired. Output file path. Extension picks the format: .png (default) or .jpg (flash/pro only — nano always returns PNG).
modelnano/flash/proflashModel tier.
ratiostring1:1e.g. 16:9, 9:16, 4:3; 21:9/1:4/4:1/1:8/8:1 are flash-only.
size0.5K/1K/2K/4K1K0.5K is flash-only.
use_searchbooleanfalseGround with Google Search (flash/pro).
use_image_searchbooleanfalseAlso use Google Image Search as visual context (flash).
show_thinkingbooleanfalseInclude the model's thought summaries (pro).
previewbooleantrueReturn a small preview image to the client.

Returns the file path and an interaction_id — pass it to edit_image to keep iterating.

edit_image

Same image controls as generate_image, plus:

ArgTypeNotes
previous_interaction_idstringContinue a previous generation/edit conversationally (the recommended way to iterate).
reference_imagesstring[]Paths to reference images on disk (max 14; flash: 10 object + 4 character, pro: 6 + 5).

generate_story

ArgTypeDefaultNotes
promptstringRequired. e.g. "A 6-panel storyboard of a fox learning to fly, illustrations interleaved with captions."
output_dirstringRequired. Directory for the numbered images.
basenamestringstoryFilename prefix.
modelnano/flash/propropro gives the best interleaved quality.
ratio / sizestringOptional; omit to let the model decide.

generate_icon_set

ArgTypeDefaultNotes
promptsstring[]Required. One prompt per icon.
output_dirstringRequired. Files are named after each prompt (icon-shopping-cart.png).
modelnano/flash/proflash
size0.5K/1K/2K/4K1K

generate_from_video

ArgTypeDefaultNotes
youtube_urlstringRequired. Public YouTube URL.
promptstringRequired. What to generate from the video.
outputstringRequired. Output file path.
ratiostring16:9
size0.5K/1K/2K/4K1K
previewbooleantrue

Prompt tips

For best results, write full sentences describing subject + setting + lighting + camera/lens + mood — narrative beats keyword soup.

A photorealistic close-up portrait of an elderly Japanese ceramicist with deep wrinkles and a warm smile. Soft golden-hour light streaming through a window. Captured with an 85mm portrait lens, soft bokeh background. Serene and masterful mood.

Requirements

  • Node.js 18+ (uses the built-in node:test runner and modern ES modules)
  • A Gemini API key (GEMINI_API_KEY)
  • The Interactions API is beta; Gemini 3 image tiers (flash, pro) may require access. The nano tier is the most widely available — set model: "nano" if flash/pro are unavailable on your key.

Development

npm test          # unit tests (node:test) — no API key needed
npm run smoke     # live smoke test — requires GEMINI_API_KEY

The codebase is split into focused modules:

  • lib/config.js — model tables, aspect-ratio/size validation, helpers
  • lib/gemini.js — API client, retries, response extraction, previews
  • lib/tools.js — tool schemas and handlers
  • index.js — MCP server wiring

License

MIT