nb-mcp
A remote MCP server that gives Claude the ability to generate and edit images with Google's nano banana (Gemini 2.5 Flash Image) model.
README
π nb-mcp β image generation MCP for Claude
A remote MCP server running on Cloudflare Workers that lets Claude generate images. Add it once as a custom connector and use it in Claude Design, claude.ai, and Claude Desktop.
- Free by default β uses Cloudflare Workers AI (Flux), no API key, no billing. Perfect for testing.
- Optional nano banana β switch to Google Gemini 2.5 Flash Image when you want (needs a key + billing).
One tool: generate_image (text β image), returned inline so Claude can see it.
Why Cloudflare Workers?
Claude's custom connectors are reached from Anthropic's cloud over the public internet, so the
server must be hosted. Cloudflare Workers is a great fit: generous free tier, one-command deploy, and
Workers AI gives free image models via the env.AI binding β so the default path needs no API key
and no billing at all.
Deploy (β2 minutes)
npm install
npx wrangler login # opens a browser; or set CLOUDFLARE_API_TOKEN
npm run deploy
Wrangler prints your URL. The MCP endpoint is:
https://nb-mcp.<your-subdomain>.workers.dev/mcp
Open the root URL in a browser to confirm it's live. That's it β the default Workers AI backend works immediately on the free tier (no key needed).
Free tier: Workers AI includes a daily free allocation, enough for plenty of test images. Deploying the Worker itself is also free.
Add it to Claude
- In Claude, go to Settings β Connectors (a.k.a. Customize β Connectors).
- Click + Add custom connector.
- Name:
nano banana(anything). URL: yourβ¦/mcpURL. - Save (no OAuth needed β leave Advanced settings empty).
- In a chat, open the + menu β Connectors and enable it, then ask Claude to make an image.
Try:
- βGenerate an image of a neon cyberpunk street market, cinematic lighting.β
- βMake a flat-vector logo of a banana wearing sunglasses on white.β
Tool: generate_image
| param | type | required | description |
|---|---|---|---|
prompt |
string | β | What to draw. Be specific about subject, style, composition, colours, lighting, mood. |
backend |
workers-ai | nano-banana |
β | Model to use. Default workers-ai (free Flux). nano-banana = Google Gemini (needs key). |
steps |
integer 1β8 | β | Workers AI (Flux) diffusion steps. Higher = better/slower. Default 4. |
Optional: enable nano banana (Gemini)
The repo keeps the original "nano banana" path as an option for when you want Google's model.
wrangler secret put GEMINI_API_KEY # paste your Google Gemini key
Then either call the tool with backend: "nano-banana", or make it the default by setting
NB_BACKEND = "nano-banana" under [vars] in wrangler.toml and redeploying.
β οΈ Gemini image generation requires billing. On Google's free tier the image model has a quota of 0 (you'll get HTTP 429). Enable billing on the project of your API key first. The default Workers AI backend has no such requirement.
Configuration
| binding / var | where | purpose |
|---|---|---|
AI |
wrangler.toml [ai] |
Workers AI binding (free image backend). Required for workers-ai. |
GEMINI_API_KEY |
wrangler secret put / .dev.vars |
Only for the nano-banana backend. |
NB_BACKEND |
[vars] |
Default backend: workers-ai (default) or nano-banana. |
NB_WORKERS_MODEL |
[vars] |
Override Workers AI model (default @cf/black-forest-labs/flux-1-schnell). |
NB_GEMINI_MODEL |
[vars] |
Override Gemini model (default gemini-2.5-flash-image). |
Local development
npm install
npx wrangler login # the AI binding always runs remotely, so dev needs auth too
npm run dev # http://localhost:8787 (endpoint: /mcp)
# in another terminal, verify the MCP protocol:
node scripts/smoke-test.mjs # local
node scripts/smoke-test.mjs https://<worker>.workers.dev/mcp # remote
For the nano-banana backend locally, copy .dev.vars.example β .dev.vars and add your key.
Security notes
- The default Workers AI backend needs no secret. A
GEMINI_API_KEY(if used) is stored as a Cloudflare secret and never sent to Claude. - The connector is unauthenticated by default β anyone with the URL can call it and use your Workers AI / Gemini quota. Keep the URL private, or add auth (Cloudflare Access in front of the Worker, or OAuth in the MCP layer).
How it works
Claude (Design / web / desktop)
β Streamable HTTP (MCP) POST /mcp
βΌ
Cloudflare Worker (src/index.ts) β stateless, hand-rolled MCP transport
β
ββ backend "workers-ai" β env.AI.run(Flux) β free, no key
ββ backend "nano-banana" β Gemini REST API β needs GEMINI_API_KEY + billing
β
βΌ
image returned inline to Claude
- Transport: stateless Streamable HTTP (
POST /mcp, SSE response). No Durable Objects, no Redis. - Runtime deps: none. Just Wrangler + TypeScript for tooling.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.