Skip to main content

Documentation Index

Fetch the complete documentation index at: https://apixo.ai/docs/llms.txt

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

Overview

Wan 2.7 Image is an Alibaba image model for text-to-image, image editing, and sequential image generation. Use this page when you are ready to call the API after trying the model in the APIXO playground.
CapabilityValue
Model IDwan-2-7-image
Modesomni-image, omni-image-pro
PromptRequired, non-empty; supports Chinese/English; max 5000 characters (model-side truncation)
Input imagesOptional image_urls, 1-9 URLs when provided
Image limits (image_urls)JPEG/JPG/PNG(no alpha)/BMP/WEBP, width/height 240-8000 px, ratio 1:8-8:1, file size <=20MB
Resolution tiers1k, 2k, 4k
4k availabilityOnly when mode=omni-image-pro, no image_urls, and enable_sequential=false
Output count (num_images)1-4 when enable_sequential=false (default 1); 1-12 when enable_sequential=true
Interactive edit boxesbbox_list requires image_urls; list length must match image count; each image supports up to 2 boxes
Color palette controlcolor_palette is available only when enable_sequential=false; 3-10 colors; ratio sum must be 100.00%

Endpoint and authentication

Base URL:
https://api.apixo.ai/api/v1
MethodEndpointPurpose
POST/generateTask/wan-2-7-imageSubmit a generation task
GET/statusTask/wan-2-7-image?taskId={taskId}Poll task status and retrieve results
All requests require your APIXO API key:
Authorization: Bearer YOUR_API_KEY
Submit requests also require:
Content-Type: application/json

Copy-paste async quickstart

This minimal request submits a text-to-image task and returns a taskId.
curl -X POST "https://api.apixo.ai/api/v1/generateTask/wan-2-7-image" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "request_type": "async",
    "input": {
      "mode": "omni-image-pro",
      "prompt": "a cinematic panda walking through snow",
      "resolution": "2k",
      "num_images": 1
    }
  }'
Successful response:
{
  "code": 200,
  "message": "success",
  "data": {
    "taskId": "task_12345678"
  }
}
Save the taskId; you need it to poll for the final result.

Poll for result

curl -X GET "https://api.apixo.ai/api/v1/statusTask/wan-2-7-image?taskId=task_12345678" \
  -H "Authorization: Bearer YOUR_API_KEY"
Processing response:
{
  "code": 200,
  "message": "success",
  "data": {
    "taskId": "task_12345678",
    "state": "processing",
    "createTime": 1767965610929
  }
}
Success response:
{
  "code": 200,
  "message": "success",
  "data": {
    "taskId": "task_12345678",
    "state": "success",
    "resultJson": "{\"resultUrls\":[\"https://file.apixo.ai/image.png\"]}",
    "createTime": 1767965610929,
    "completeTime": 1767965652317,
    "costTime": 41388
  }
}
Failed response:
{
  "code": 200,
  "message": "success",
  "data": {
    "taskId": "task_12345678",
    "state": "failed",
    "failCode": "InvalidParameter",
    "failMsg": "The parameter is invalid",
    "createTime": 1767965610929,
    "completeTime": 1767965620132
  }
}
Parse resultJson after state becomes success:
const payload = JSON.parse(data.resultJson);
const imageUrls = payload.resultUrls;

Request body

Text-to-image

{
  "request_type": "async",
  "input": {
    "mode": "omni-image-pro",
    "prompt": "a cinematic panda walking through snow",
    "resolution": "4k",
    "num_images": 2,
    "enable_sequential": false,
    "watermark": false,
    "seed": 42
  }
}

Image editing

{
  "request_type": "callback",
  "callback_url": "https://your-server.com/webhooks/apixo",
  "input": {
    "mode": "omni-image",
    "image_urls": [
      "https://example.com/base.png",
      "https://example.com/style.png"
    ],
    "prompt": "blend the style naturally and keep lighting consistent",
    "resolution": "2k",
    "num_images": 1,
    "bbox_list": [
      [[120, 180, 360, 420]],
      []
    ]
  }
}

Parameters

request_type
string
default:"async"
required
Result delivery mode. Use async for polling with statusTask, or callback for webhook delivery.
callback_url
string
Required when request_type is callback. Must be a callback URL that can receive the final task payload. See Webhooks.
input
object
required
Wan 2.7 Image input parameters.

Response format

Submit task response

POST /generateTask/wan-2-7-image returns a task ID when the task is accepted:
code
integer
API status code. 200 means the task was accepted.
message
string
Human-readable status message.
data.taskId
string
Unique task identifier used with the status endpoint.

Status response fields

taskId
string
Unique task identifier.
state
string
Current task state: pending, processing, success, or failed.
resultJson
string
JSON string containing generated image URLs in resultUrls. Present when state is success.
failCode
string
Machine-readable failure code. Present when state is failed.
failMsg
string
Human-readable failure message. Present when state is failed.
createTime
integer
Task creation timestamp in Unix milliseconds.
completeTime
integer
Task completion timestamp in Unix milliseconds. Present after completion.
costTime
integer
Processing duration in milliseconds. Present after completion when provider timing is available.
If at least one image succeeds, the task can still return success, and resultJson.resultUrls contains only successful outputs.

Webhook callback mode

Use callback mode when your backend should receive the final result automatically instead of polling.
curl -X POST "https://api.apixo.ai/api/v1/generateTask/wan-2-7-image" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "request_type": "callback",
    "callback_url": "https://your-server.com/webhooks/apixo",
    "input": {
      "mode": "omni-image-pro",
      "prompt": "a premium product poster with soft studio light",
      "resolution": "2k",
      "num_images": 1
    }
  }'
See Webhooks for delivery requirements and retry behavior.

Billing

Wan 2.7 Image is billed per generated image.
ModeAPIXO price
omni-image$0.03 / image
omni-image-pro$0.075 / image
Billing behavior:
precharge = requested_num_images * unit_price
final_charge = successful_images * unit_price
refund = precharge - final_charge (if partial failure)
For current public pricing, see Pricing. If this route is not listed there, backend billing follows ModelPricing.md.

Latency and polling

Wan 2.7 Image tasks are asynchronous. The backend does not provide a fixed public latency SLA; actual latency varies by prompt complexity, requested image count, image input fetch speed, and queue load.
WorkflowRecommended first pollPoll interval
Text-only generation10s after task creation5s-10s
Image editing / multi-image input10s-15s after task creation5s-10s
Sequential generation (enable_sequential=true)15s after task creation8s-12s
For production workloads, use callback mode to avoid frequent polling.
Rate limits and concurrency can vary by account, API key, and route. If you receive 429, slow down requests and retry with backoff. For account-level details, see System APIs.

Errors and troubleshooting

HTTP errors

CodeMeaningWhat to do
400Invalid request body, parameter type, or valueFix the request before retrying
401Missing or invalid API keyCheck the Authorization header
402Insufficient balance or quotaAdd balance or switch account/key
403Key or route cannot access the modelCheck permissions and route strategy
429Rate limit or concurrency limit reachedRetry with exponential backoff
500Server errorRetry with backoff
502Third-party model service errorRetry with backoff
504Third-party model timeoutRetry or use callback mode

Task failure codes

failCode is route-dependent and may come from mapped third-party model failures. Common values include:
Fail codeMeaningWhat to do
PromptInvalidPrompt is invalid or rejected by the model serviceRewrite the prompt and retry
MissingParameter / BadRequestRequired fields are missing or malformedCheck required fields and types
SensitiveContentDetected / ProhibitedContentDetectedPrompt or image input failed safety checksRewrite prompt or change input images
RateLimitExceededModel service or route rate limit was reachedRetry with backoff
Task TimeOut / TimeoutGeneration did not finish in timeRetry or use callback mode

Parameter troubleshooting

  • mode must be omni-image or omni-image-pro.
  • prompt is required and cannot be empty.
  • resolution supports only 1k, 2k, 4k.
  • 4k is invalid when mode=omni-image, when enable_sequential=true, or when image_urls is provided.
  • num_images range depends on enable_sequential: 1-4 when false, 1-12 when true.
  • image_urls supports 1-9 image URLs when provided.
  • bbox_list requires image_urls, its length must match image_urls, and each image supports at most 2 boxes.
  • color_palette is available only when enable_sequential=false, with 3-10 colors and total ratio 100.00%.
See Error Codes for the full error reference.