Wan 2.7 API

video

Video generation by alibaba

Multimodal Wan 2.7 video generation with text, frame control, and reference-image guidance.

Call Wan 2.7 from Node.js, Python, or any HTTP client. No GPU provisioning, no cold starts, no Docker images — just an API key and a prompt.

Free credits included. Powering 1M+ generations daily.

Start in 60 seconds

Install the official SDK for Node.js or Python, drop in your API key, and generate your first video.

npm install getimg-ai
import GetimgAI from "getimg-ai";

const client = new GetimgAI();

const submission = await client.videos.generations.create({
    model: "wan-2-7",
    prompt: "3D robot made out of tiny dust-like voxels, looking to the left, smoothly desintegrating into background, medium portrait shot, purple monochrome",
    aspect_ratio: "16:9",
    resolution: "720p",
    duration: 2
  });
const requestId = submission.id;

// Poll
let result;
while (true) {
  result = await client.videos.generations.retrieve(requestId);

  if (result.status === "completed") break;
  if (result.status === "failed") {
    throw new Error(result.error.message);
  }

  await new Promise((r) => setTimeout(r, 5000));
}

console.log(result.data[0].url);

How Wan 2.7 API works

Submit a generation request, poll for completion, download the video.

1

Get your API key

Create a key in the Developer Dashboard. Free credits included.

2

Send a request

POST to /v2/videos/generations with your prompt, duration, and resolution.

3

Get your video

Poll the status endpoint. When it completes, download the video from the returned URL.

What you can build with Wan 2.7

Every example uses the same authentication and works with the official getimg-ai and getimg SDKs, or plain HTTP.

Text to video

Generate a video using just a text prompt.

import GetimgAI from "getimg-ai";

const client = new GetimgAI();

const submission = await client.videos.generations.create({
    model: "wan-2-7",
    prompt: "3D robot made out of tiny dust-like voxels, looking to the left, smoothly desintegrating into background, medium portrait shot, purple monochrome",
    aspect_ratio: "16:9",
    resolution: "720p",
    duration: 2
  });
const requestId = submission.id;

// Poll
let result;
while (true) {
  result = await client.videos.generations.retrieve(requestId);

  if (result.status === "completed") break;
  if (result.status === "failed") {
    throw new Error(result.error.message);
  }

  await new Promise((r) => setTimeout(r, 5000));
}

console.log(result.data[0].url);

Image to video

Animate a still image as the starting frame.

import GetimgAI from "getimg-ai";

const client = new GetimgAI();

const submission = await client.videos.generations.create({
    model: "wan-2-7",
    prompt: "Animate the scene with subtle camera movement and natural motion.",
    aspect_ratio: "16:9",
    resolution: "720p",
    duration: 2,
    images: [
      {
        url: "https://your-bucket.s3.amazonaws.com/first.png",
        role: "first_frame"
      }
    ]
  });
const requestId = submission.id;

// Poll
let result;
while (true) {
  result = await client.videos.generations.retrieve(requestId);

  if (result.status === "completed") break;
  if (result.status === "failed") {
    throw new Error(result.error.message);
  }

  await new Promise((r) => setTimeout(r, 5000));
}

console.log(result.data[0].url);

First & last frame

Interpolate motion between a starting and ending frame.

import GetimgAI from "getimg-ai";

const client = new GetimgAI();

const submission = await client.videos.generations.create({
    model: "wan-2-7",
    prompt: "Smooth transition from the first to the last frame.",
    aspect_ratio: "16:9",
    resolution: "720p",
    duration: 2,
    images: [
      {
        url: "https://your-bucket.s3.amazonaws.com/first.png",
        role: "first_frame"
      },
      {
        url: "https://your-bucket.s3.amazonaws.com/last.png",
        role: "last_frame"
      }
    ]
  });
const requestId = submission.id;

// Poll
let result;
while (true) {
  result = await client.videos.generations.retrieve(requestId);

  if (result.status === "completed") break;
  if (result.status === "failed") {
    throw new Error(result.error.message);
  }

  await new Promise((r) => setTimeout(r, 5000));
}

console.log(result.data[0].url);

Reference image

Guide the generation with a character, style, or content reference.

import GetimgAI from "getimg-ai";

const client = new GetimgAI();

const submission = await client.videos.generations.create({
    model: "wan-2-7",
    prompt: "A cinematic shot inspired by the provided reference image.",
    aspect_ratio: "16:9",
    resolution: "720p",
    duration: 2,
    images: [
      {
        url: "https://your-bucket.s3.amazonaws.com/reference.png",
        role: "reference_image"
      }
    ]
  });
const requestId = submission.id;

// Poll
let result;
while (true) {
  result = await client.videos.generations.retrieve(requestId);

  if (result.status === "completed") break;
  if (result.status === "failed") {
    throw new Error(result.error.message);
  }

  await new Promise((r) => setTimeout(r, 5000));
}

console.log(result.data[0].url);

Wan 2.7 pricing

Pay per video. No subscriptions, no minimums, no idle GPU costs.

Wan 2.7

$0.10 – $0.15 /second

/v2/videos/generations

Multimodal Wan 2.7 video generation with text, frame control, and reference-image guidance.

ResolutionPrice5s videos for $10
720p$0.10 /second20
1080p$0.15 /second13

More from alibaba

Other alibaba models available through the same API.

Wan 2.7 API — frequently asked questions

How do I use the Wan 2.7 API?

Install the official Node.js (npm install getimg-ai) or Python (pip install getimg) SDK, or call the endpoint directly over HTTP from any client.

Make a POST request to /v2/videos/generations with your API key and a JSON body containing the model ID (wan-2-7) and a prompt. The API returns a request ID. Poll the status endpoint until the video is ready.

See the API documentation for the full parameter reference.

Which SDK should I use?

Use getimg-ai for Node.js and TypeScript projects, and getimg for Python. Both wrap the same REST API with typed inputs, retries, and built-in polling for video generations.

For other languages — Go, Rust, Java, Ruby, PHP — call the HTTP endpoints directly. Every example on this page includes a cURL snippet you can port to any HTTP client.

What resolutions does Wan 2.7 support?

Wan 2.7 supports the following resolutions: 720p, 1080p across 5 aspect ratios (16:9, 9:16, 1:1, 4:3, 3:4). Videos can be 2 to 15 seconds long.

How much does Wan 2.7 cost?

Wan 2.7 uses pay-per-video pricing with no subscriptions or minimum commitments. Rates vary by resolution and sound options. See the pricing table above for exact rates per second.

Does Wan 2.7 support reference images?

Yes. Wan 2.7 accepts up to 1 last frame and up to 1 first frame and up to 5 reference images. Reference images guide the generation toward a specific style, composition, or subject. See the example above.

Start building with Wan 2.7

Grab an API key, install the SDK, ship video generation today.

Looking for other models? View all available models