AI image generation, video generation, music creation, text-to-speech, prompt search, and LLM chat — 130+ models from Flux, Kling, Seedance, Veo, Suno, ElevenLabs, Claude, GPT, Gemini, and 18 providers in one MCP server.
Works with Claude Code, Codex, Cursor, Windsurf, VS Code, Roo Code, and any MCP-compatible host.
Quick Start | Tools | Examples | Catalog | Platforms
RunAPI MCP Server connects MCP-compatible coding tools to RunAPI. It lets an assistant browse the RunAPI catalog, inspect model inputs, check current pricing snapshots, create media tasks, poll task status, check account balance, and call RunAPI LLM endpoints.
The discovery tools work without an API key because they use the embedded build-time catalog.
Authenticated operations require RUNAPI_API_KEY.
This package is a pure client. It does not run a local generation backend and does not require changes to your RunAPI account beyond creating an API key for authenticated tools.
For Claude Code, Cursor, Windsurf, and VS Code, install RunAPI with Claude Code's MCP command:
claude mcp add runapi -s user -- npx -y @runapi.ai/mcpThe scope flag controls where the MCP server is stored:
-s user: global, available in all projects for your user.-s project: team-shared, written to.mcp.jsonin the current repo so it can be committed.
Use project scope when you want the whole team to share the same server config:
claude mcp add runapi -s project -- npx -y @runapi.ai/mcpCompatibility fallback for non-Claude Code platforms or manual JSON config:
{
"mcpServers": {
"runapi": {
"command": "npx",
"args": ["-y", "@runapi.ai/mcp"],
"env": {
"RUNAPI_API_KEY": "${RUNAPI_API_KEY}"
}
}
}
}If your host needs a generated config file, use the legacy init command as a fallback:
npx @runapi.ai/mcp init claude
npx @runapi.ai/mcp init cursor
npx @runapi.ai/mcp init vscode
npx @runapi.ai/mcp init windsurf
npx @runapi.ai/mcp init rooFree catalog tools work even when RUNAPI_API_KEY is not configured.
For task creation, balance checks, and LLM chat, create an API key in the RunAPI dashboard and expose it as RUNAPI_API_KEY.
| Tool | Auth | Purpose |
|---|---|---|
list_models |
No | List RunAPI models from the embedded catalog. Supports modality, service, and action filters. |
get_model_info |
No | Return service, action, modality, input constraints, and pricing snapshot for a model slug. Use service + action when a model appears in multiple endpoints. |
list_actions |
No | Group endpoint action names by modality. |
check_pricing |
No | Return pricing snapshot data for a service + action + model combination. |
search_prompts |
No | Search reusable prompt examples by modality, category, tags, q, model, featured, and pagination. |
create_task |
Yes | Create a media task and optionally poll until completion. |
get_task |
Yes | Fetch status and latest payload for an existing media task. |
check_balance |
Yes | Return account balance and spending metrics. |
chat |
Yes | Send messages to a RunAPI LLM endpoint and return the response with usage metadata when available. |
The catalog, pricing, and prompt search tools are designed for funnel-top discovery inside coding tools. The task, balance, and chat tools are designed for authenticated workflows.
Ask your assistant natural-language questions. The assistant should use the tools to discover current model slugs and pricing instead of relying on memorized names.
What RunAPI image models are available?
Expected behavior:
- The assistant calls
list_modelswithmodality: "image". - It summarizes the returned model slugs, services, actions, and required fields.
- It avoids quoting stale prices unless it calls
check_pricing.
Find image prompt examples for a logo.
Expected behavior:
- The assistant calls
search_promptswithmodality: "image"andq: "logo". - It summarizes returned titles, prompt text, model slugs, categories, and tags.
- It uses the selected prompt with
get_model_infobefore creating a task.
Show me the required parameters for this model slug: <model-slug>
Expected behavior:
- The assistant calls
get_model_info. - If the response is ambiguous, it chooses the relevant service/action from the returned matches and calls
get_model_infoagain withserviceandaction. - It shows required fields, enum constraints, range constraints, conditional input rules, supported action, and pricing snapshot if present.
- It tells you to choose another slug with
list_modelsif the slug is not found.
Generate a square product image with RunAPI. Pick a suitable image model.
Expected behavior:
- The assistant calls
list_modelsto choose a compatible image model. - It calls
get_model_infowith the selected service/action/model to validate parameters and any conditional input rules. - It asks for confirmation if the request is expensive, long-running, or a batch.
- It calls
create_task. - It returns task ID, status, output URLs, and cost fields when available.
Create the task but do not wait for completion.
Expected behavior:
- The assistant calls
create_taskwithwait: false. - It returns the task ID.
- You can later ask for status with
get_task.
Check my RunAPI balance.
Expected behavior:
- The assistant calls
check_balance. - If no key is configured, it explains how to set
RUNAPI_API_KEY.
Use a RunAPI LLM model to summarize this file.
Expected behavior:
- The assistant uses catalog tools to identify a current LLM model slug when needed.
- It calls
chatrather thancreate_task. - It returns the model response and usage metadata when available.
The embedded catalog is generated from RunAPI's contract snapshot. It includes media models, utility endpoints, and LLM model slugs.
| Modality | What To Use |
|---|---|
| Image | list_models with modality: "image" |
| Video | list_models with modality: "video" |
| Audio and music | list_models with modality: "audio" |
| LLM | list_models with modality: "llm" |
| Utility | list_models with modality: "utility" |
Catalog contents can change between releases.
Use list_models for current service/action/model slugs and get_model_info for each model's current constraints.
RunAPI pricing is exposed through the check_pricing tool and the public pricing page.
Do not rely on examples in README files for exact prices.
Useful flows:
- Call
list_modelsto find a candidate model. - Call
check_pricingwithservice,action, andmodel. - Show the returned pricing snapshot or link to runapi.ai/pricing.
Free catalog tools do not create tasks and do not consume account balance.
Run:
claude mcp add runapi -s user -- npx -y @runapi.ai/mcpUse -s user for a global install available in all projects.
Use -s project when you want Claude Code to write .mcp.json in the repo for team-shared config.
Restart or reload your MCP host after changing MCP configuration.
Use init only when a host needs a platform-specific JSON file or cannot use the Claude Code MCP command.
Claude Code fallback:
npx @runapi.ai/mcp init claudeThis writes .mcp.json in the current directory.
Cursor fallback:
npx @runapi.ai/mcp init cursorThis writes .cursor/mcp.json.
Open Cursor settings to verify the MCP server is enabled.
VS Code fallback:
npx @runapi.ai/mcp init vscodeThis writes .vscode/mcp.json.
VS Code uses a top-level servers key and type: "stdio" in generated config.
Windsurf fallback:
npx @runapi.ai/mcp init windsurfThis writes the generated config for the Windsurf target used by the init command.
Run:
npx @runapi.ai/mcp init rooThis writes .roo/mcp.json.
Use the example files in examples/ as starting points.
Each platform has slightly different wrapper keys and file paths, but all run the same command:
npx -y @runapi.ai/mcpThe server reads configuration in this order:
RUNAPI_API_KEYenvironment variable~/.config/runapi/config.json- No key, which still allows free catalog tools
Example config file:
{
"apiKey": "your_runapi_key"
}You can also set a custom base URL for local testing:
{
"apiKey": "your_runapi_key",
"baseUrl": "https://runapi.ai"
}Do not commit real API keys.
This package ships build-time data files:
data/contract.json: catalog, actions, model slugs, and input constraintsdata/pricing.json: pricing snapshot used bycheck_pricing
Refresh data from the RunAPI source tree before a release:
npm run sync:dataBuild-time data means a pricing or catalog update requires a new package release.
npm install
npm run typecheck
npm test
npm pack --dry-runRun the server locally:
npm run devManual initialize smoke test:
printf '%s\n' '{"jsonrpc":"2.0","method":"initialize","params":{"protocolVersion":"2025-03-26","capabilities":{},"clientInfo":{"name":"test","version":"0.1.0"}},"id":1}' | npx tsx src/index.tsThe npm package includes:
- compiled
dist/files - embedded
data/files - platform examples
- eval scenarios, when generated by this repo
- README, changelog, license, and package metadata
It does not include node_modules, .env, local config files, or API keys.
RunAPI also has a separate command-line client for terminal workflows. Use this MCP server when you want RunAPI available inside an MCP host. Use the CLI when you want direct shell commands, scripts, or CI integration.
Licensed under the Apache License, Version 2.0.