wan-2.5-text-to-video API
Use wan-2.5-text-to-video from the Wan family via RunAPI. Per-call pricing, no subscription, and failed generations are never charged.
curl -X POST https://runapi.ai/api/v1/wan/text_to_video \
-H "Authorization: Bearer $RUNAPI_KEY" \
-H "Content-Type: application/json" \
-d '{
"model": "wan-2.5-text-to-video",
"prompt": "Generate a 5-second video of a cat jumping onto a bookshelf, natural indoor lighting, handheld camera feel."
}'
import { WanClient } from "@runapi.ai/wan";
const client = new WanClient();
const result = await client.textToVideo.run({
model: "wan-2.5-text-to-video",
prompt: "Generate a 5-second video of a cat jumping onto a bookshelf, natural indoor lighting, handheld camera feel.",
});
<?php
require __DIR__ . "/vendor/autoload.php";
use RunApi\Wan\WanClient;
$client = new WanClient();
$result = $client->textToVideo->run([
'model' => 'wan-2.5-text-to-video',
'prompt' => 'Generate a 5-second video of a cat jumping onto a bookshelf, natural indoor lighting, handheld camera feel.',
]);
require "runapi/wan"
client = RunApi::Wan::Client.new
result = client.text_to_video.run(
model: "wan-2.5-text-to-video",
prompt: "Generate a 5-second video of a cat jumping onto a bookshelf, natural indoor lighting, handheld camera feel."
)
npx skills add runapi-ai/wan -g
# Claude Code
claude mcp add runapi -s user -- npx -y @runapi.ai/mcp
# Codex
codex plugin install runapi-mcp@agents
# Cursor / Windsurf / VS Code
npx @runapi.ai/mcp init cursor
wan-2.5-text-to-video targets the sweet spot of quality and cost within the Wan family. It shares the same API key, request shape, and async task lifecycle as every other RunAPI model — switch to this variant by changing one model ID parameter. Install the Wan skill to load docs, typed schemas, pricing notes, and setup steps into your coding workspace. Billing is metered per completed request in USD with no subscription or minimum spend, and failed generations are never charged.
- Pay-per-call pricing in USD with no subscription
- Failed generations are never charged
- Streaming when supported by the model
- Schema-validated parameters and tool calls
- Switch variant by changing one model ID parameter
- Unified billing across all models and providers
Pricing
Technical details
| Model ID | wan-2.5-text-to-video |
| Provider | Alibaba |
| Modality | video |
| Task type | asynchronous |
| Billing unit | second |
| API endpoint | /api/v1/wan/text_to_video |
| Commercial license | Yes — included via API |
| Status | Operational |
Model skill — wan-2.5-text-to-video
Install the skill once, then use the variant ID from this page while building.
# Install the model skill for app development workflows
npx skills add runapi-ai/wan -g
Install the Wan skill for this app: 1. Add runapi-ai/wan with the skills installer. 2. Load SKILL.md in this workspace. 3. Use its docs, schemas, pricing notes, and setup steps when adding model features. 4. Confirm the install path when done.
Use wan-2.5-text-to-video with a model skill
Install
Install the model skill for the %{model} line. The skill loads docs, typed schemas, pricing notes, and setup steps into your coding workspace so your agent has the right context.
Configure
Set the model field to the full model ID shown on this page and configure your RunAPI API key as an environment variable. The same key works across all models and providers.
Call
Use the skill instructions while adding prompt, input, and callback handling to your application. RunAPI routes the request to the provider, manages the async lifecycle, and returns structured JSON.
Receive
Read the task response by polling the task ID, streaming when supported, or handling the webhook callback at your configured URL. Generated outputs are stored and retrievable by task ID.
What's different about wan-2.5-text-to-video
Native audio generation + better motion realism vs 2.2
Image-anchored video on the 2.2 architecture
Native audio generation + better motion realism vs 2.2
Audio input drives video motion and lip-sync
Native audio generation + better motion realism vs 2.2
Open-source MoE; runs on 12 GB VRAM; baseline quality
Best for
Ad & social content
Generate product launch clips and short-form ads from a text brief, cutting production from weeks to hours.
E-learning
Convert lesson scripts into animated explainer videos at scale without a camera or crew.
Creator workflows
Produce viral short-form content for social platforms directly from a prompt.
Frequently asked questions about wan-2.5-text-to-video
Is the model ID stable across versions?
Yes. RunAPI keeps the model ID stable and handles compatible version refreshes without changing your request shape. You do not need to update your code when the provider releases a new compatible version.
What's the rate limit on this variant?
Per-key rate limits scale with your usage tier. The pricing page shows current limits. If you need higher throughput, contact support to discuss tier upgrades.
Can I switch variants later?
Yes. Variant is a parameter in the request. Switch by changing the model ID — no code changes, no re-authentication, no separate billing setup. All variants share the same API key and request shape.
Does it stream?
Where streaming is available, RunAPI streams end-to-end. LLM models support token-level streaming. Media models use async task polling or webhook callbacks for result delivery.
Where do I report quality issues?
Open an issue on the public GitHub repo or email support at [email protected]. Include the task ID and model ID so the team can investigate the specific generation.
Do I need a separate provider account?
No. Your RunAPI API key is enough to access this variant and every other model in the catalog. You do not need accounts with the underlying provider.