Skip to content

runapi-ai/wan-mcp

Repository files navigation

RunAPI Wan MCP Server

Wan API access for AI agents: create image and video generation tasks, poll results, and check pricing through one focused MCP server.

Works with Claude Code, Codex, Cursor, Windsurf, VS Code, Roo Code, and any MCP-compatible host.

npm version GitHub repository Apache-2.0 license MCP Server 18 models

Install | Tools | Models | Agent Prompts | Configuration | Links


Why This Package?

@runapi.ai/wan-mcp is a focused Model Context Protocol server for the Wan model line on RunAPI. It gives MCP-compatible assistants direct access to 6 endpoints and 18 model variants without loading the full RunAPI catalog.

Use this per-model server when an agent should stay scoped to Wan. Use @runapi.ai/mcp when one assistant should discover every RunAPI model line.


Install

Add it to Claude Code:

claude mcp add wan -s user -- npx -y @runapi.ai/wan-mcp

Use project scope when the server should be shared with a repository:

claude mcp add wan -s project -- npx -y @runapi.ai/wan-mcp

Codex, Cursor, Windsurf, VS Code, Roo Code, and other MCP hosts can use the same stdio command:

{
  "mcpServers": {
    "wan": {
      "command": "npx",
      "args": ["-y", "@runapi.ai/wan-mcp"],
      "env": { "RUNAPI_API_KEY": "${RUNAPI_API_KEY}" }
    }
  }
}

Create an API key at runapi.ai and expose it as RUNAPI_API_KEY. check_pricing can run without a key; task creation and status polling require one.

Ready-made examples are in examples/ for Claude, Cursor, Windsurf, VS Code, and Roo Code.


Tools

Tool Auth Purpose
animate Yes Create a Wan animate task and optionally wait for a terminal status. Returns the task id, status, output URLs, and pricing snapshot.
edit_video Yes Create a Wan edit video task and optionally wait for a terminal status. Returns the task id, status, output URLs, and pricing snapshot.
image_to_video Yes Create a Wan image to video task and optionally wait for a terminal status. Returns the task id, status, output URLs, and pricing snapshot.
speech_to_video Yes Create a Wan speech to video task and optionally wait for a terminal status. Returns the task id, status, output URLs, and pricing snapshot.
text_to_image Yes Create a Wan text to image task and optionally wait for a terminal status. Returns the task id, status, output URLs, and pricing snapshot.
text_to_video Yes Create a Wan text to video task and optionally wait for a terminal status. Returns the task id, status, output URLs, and pricing snapshot.
get_task Yes Fetch the current status and latest payload for an existing task.
check_pricing No Look up the current pricing snapshot for a Wan model and endpoint.

Models

Wan covers 18 model variants across 6 endpoints. Each tool accepts the models listed for it:

Tool Models
animate wan-2.2-animate-move, wan-2.2-animate-replace
edit_video wan-2.6-edit-video, wan-2.6-flash-edit-video, wan-2.7-edit-video
image_to_video wan-2.2-a14b-image-to-video-turbo, wan-2.5-image-to-video, wan-2.6-flash-image-to-video, wan-2.6-image-to-video, wan-2.7-image-to-video
speech_to_video wan-2.2-a14b-speech-to-video-turbo
text_to_image wan-2.7-image, wan-2.7-image-pro
text_to_video wan-2.2-a14b-text-to-video-turbo, wan-2.5-text-to-video, wan-2.6-text-to-video, wan-2.7-r2v, wan-2.7-text-to-video

Model availability can change between releases. Use check_pricing or the Wan model page for the current catalog view.


Agent Prompts

Ask your assistant in natural language; it can inspect pricing, create the task, and return the task id plus output URLs.

Create a task

Run a Wan animate task with RunAPI.

The assistant can call check_pricing, then animate, and return the task id, status, and output URLs.

Submit without waiting

Create the task but don't wait for it to finish.

The assistant calls the create tool with wait: false and returns the task id. Check on it later with get_task.

Check pricing before creating

Check current Wan pricing, then create the task if it matches my request.

The assistant calls check_pricing and can link to the Wan model page for the canonical catalog entry.


Configuration

The server reads the API key in this order:

  1. RUNAPI_API_KEY environment variable
  2. ~/.config/runapi/config.json

Example config file:

{
  "apiKey": "your_runapi_key"
}

Do not commit real API keys. Get one at runapi.ai.


Links

Resource URL
Wan model page https://runapi.ai/models/wan
npm package @runapi.ai/wan-mcp
GitHub repository runapi-ai/wan-mcp
RunAPI MCP overview runapi.ai/mcp
RunAPI docs runapi.ai/docs

License

Licensed under the Apache License, Version 2.0.