Skip to main content
POST
/
wan
/
api
/
v1
/
services
/
aigc
/
video-generation
/
video-synthesis
Video edit: create an edit task from a video + reference images + instruction
curl --request POST \
  --url https://api.apiyi.com/wan/api/v1/services/aigc/video-generation/video-synthesis \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --header 'X-DashScope-Async: <x-dashscope-async>' \
  --data @- <<EOF
{
  "model": "wan2.7-videoedit",
  "input": {
    "prompt": "Replace the girl's outfit in the video with the outfit in the image",
    "media": [
      {
        "type": "video",
        "url": "https://your-cdn.com/source.mp4"
      },
      {
        "type": "reference_image",
        "url": "https://your-cdn.com/new-clothes.png"
      }
    ]
  }
}
EOF
{
  "output": {
    "task_id": "3b216861-6a5f-441d-a438-602ab2c0d103",
    "task_status": "PENDING"
  },
  "request_id": "..."
}

Documentation Index

Fetch the complete documentation index at: https://docs.apiyi.com/llms.txt

Use this file to discover all available pages before exploring further.

The Playground on the right lets you debug directly: put Bearer sk-your-api-key in Authorization, fill in model / input.media / parameters, and send the request. A successful submission returns a task_id; see below for polling and download.
This page is the creation endpoint for wan2.7-videoedit (video edit): give a video + 1-5 reference images + a natural-language edit instruction to edit video elements, such as swapping outfits or backgrounds. Note the model name has no hyphen (videoedit). For the full async flow, see the Wan Overview.
  • input.media must contain both a video (the video being edited) and at least one reference_image (the reference asset, ≤5).
  • The model name is wan2.7-videoedit (no hyphen), different from HappyHorse’s happyhorse-1.0-video-edit (with hyphens), so don’t mix them up.
  • Creation requests go to /wan/api/v1/... with X-DashScope-Async: enable; do not use /v1/videos.

Code examples

curl -X POST "https://api.apiyi.com/wan/api/v1/services/aigc/video-generation/video-synthesis" \
  -H "X-DashScope-Async: enable" \
  -H "Authorization: Bearer sk-your-api-key" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "wan2.7-videoedit",
    "input": {
      "prompt": "Replace the girl's outfit in the video with the outfit in the image",
      "media": [
        {"type": "video",           "url": "https://your-cdn.com/source.mp4"},
        {"type": "reference_image", "url": "https://your-cdn.com/new-clothes.png"}
      ]
    },
    "parameters": {"resolution": "720P", "prompt_extend": true, "watermark": true}
  }'

Parameter and media quick reference

ParameterTypeRequiredDefaultNotes
modelstringFixed wan2.7-videoedit
input.promptstringNatural-language edit instruction
input.mediaarraySee the media table below
parameters.resolutionstring720P720P / 1080P
parameters.prompt_extendbooltrueSmart rewriting
parameters.watermarkboolfalse”AI generated” watermark

media[] values

typeRequiredCountNotes
video1The source video being edited
reference_image1-5Reference asset (new outfit, new background, etc.)
The video edit output duration follows the input video, not the duration parameter, so this capability usually does not pass duration.

Response format

{
  "output": { "task_id": "3b216861-6a5f-441d-a438-602ab2c0d103", "task_status": "PENDING" },
  "request_id": "..."
}
After submitting, poll GET /v1/tasks/{task_id} until completed, then download the mp4 from result_url (no Authorization header, expires in 24 hours). For the full loop, see Wan Overview · Async call flow.

Authorizations

Authorization
string
header
required

The API Key obtained from the APIYI console

Headers

X-DashScope-Async
enum<string>
default:enable
required

Async processing switch; must be set to enable

Available options:
enable

Body

application/json
model
enum<string>
default:wan2.7-videoedit
required

Model ID, fixed wan2.7-videoedit (no hyphen)

Available options:
wan2.7-videoedit
input
object
required
parameters
object

Response

Task submitted; returns task_id and PENDING status

output
object
request_id
string

Unique request identifier

Example:

"..."