Băng hình
Tạo các video clip với mô hình tác vụ không đồng bộ — gửi lời nhắc, thăm dò trạng thái, tìm nạp kết quả.
Quá trình tạo video chạy ở chế độ nền - không có kết xuất phát trực tuyến. Quy trình luôn là: tạo tác vụ → trạng thái thăm dò → tải xuống MP4. Nhiệm vụ hết hạn sau 24 giờ.
1. Tạo nhiệm vụ
Gửi công việc và trả về ID nhiệm vụ. Chi phí được ghi nợ trước dựa trên thời lượng × giá mỗi giây cho kiểu máy đã chọn.
https://api.airforce/v1/video/generationsMô hình video
…· live| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | Video model ID. Use /v1/models and filter by output_modalities.includes("video"). |
| prompt | string | Required | Scene description. |
| mode | string | Optional | "text" (default), "image" (animate a first-frame image), "reference" (style transfer from one or more frames). |
| duration_seconds | integer | Optional | Clip length. Range depends on the model — typically 5, 8 or 10 s. Defaults to the model's minimum. |
| aspect_ratio | string | Optional | "16:9", "9:16", "1:1", "4:3" — must be in the model's supported list. |
| quality | string | Optional | "480p", "720p", "1080p" — must be in the model's supported list. |
| input_images | array | Optional | [{ url? } | { b64_json? }] — required for "image" and "reference" modes. |
| seed | integer | Optional | Reproducibility seed where supported. |
| sound | boolean | Optional | Enable native audio track on models that produce sound (e.g. wan). |
Ví dụ
Chuyển văn bản thành video
curl https://api.airforce/v1/video/generations \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"model": "wan-2.6",
"prompt": "A red fox darting across snowy hills at dawn",
"duration_seconds": 8,
"aspect_ratio": "16:9",
"quality": "720p",
"sound": true
}'Chuyển hình ảnh thành video (khung hình đầu tiên)
curl https://api.airforce/v1/video/generations \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"model": "kling-1",
"mode": "image",
"prompt": "Camera pulls back as the dragon takes off",
"duration_seconds": 5,
"aspect_ratio": "16:9",
"input_images": [{"url": "https://example.com/dragon.jpg"}]
}'Phản ứng
| Parameter | Type | Required | Description |
|---|---|---|---|
| task_id | string | Optional | Persistent task identifier. Use it on every follow-up endpoint. |
| status | string | Optional | "queued" right after creation. |
| model | string | Optional | Echo of requested model. |
| created | integer | Optional | Unix timestamp. |
| expires_at | integer | Optional | Unix timestamp after which the result is purged (typically created + 86400). |
| cost_cents | number | Optional | Up-front cost debited from your balance. Refunded if the task ultimately fails. |
{
"task_id": "vid_01HXY1234ABCD",
"status": "queued",
"model": "wan-2.6",
"created": 1715000000,
"expires_at": 1715086400,
"cost_cents": 320
}2. Thăm dò trạng thái
Thăm dò ý kiến cứ sau 5–15 giây. Nhiệm vụ thường hoàn thành trong 30 giây - 4 phút tùy thuộc vào thời lượng và kiểu máy. Điểm cuối tương tự trả về URL kết quả khi trạng thái chuyển sang "hoàn thành".
https://api.airforce/v1/video/tasks/:task_id| Parameter | Type | Required | Description |
|---|---|---|---|
| status | string | Optional | "queued" | "running" | "completed" | "failed" | "expired". |
| progress | integer | Optional | 0–100 while running. Absent for queued tasks. |
| result_url | string | Optional | MP4 download URL once status is "completed". Pre-signed; valid until expires_at. |
| thumbnail_url | string | Optional | Optional poster frame. |
| error | object | Optional | Set when status is "failed". { type, message }. |
| cost_cents | number | Optional | Final cost. Equals the create-time cost on success. |
{
"task_id": "vid_01HXY1234ABCD",
"status": "completed",
"progress": 100,
"result_url": "https://cdn.api.airforce/video/vid_01HXY1234ABCD.mp4",
"thumbnail_url": "https://cdn.api.airforce/video/vid_01HXY1234ABCD.jpg",
"model": "wan-2.6",
"duration_seconds": 8,
"expires_at": 1715086400,
"cost_cents": 320
}2b. Tiến trình truyền phát (tùy chọn)
Bỏ qua vòng bỏ phiếu với luồng Sự kiện do máy chủ gửi. Phát ra một sự kiện cho mỗi thay đổi tiến trình và đóng khi tác vụ ở trạng thái cuối. Hình dạng tải trọng giống như điểm cuối GET.
https://api.airforce/v1/video/tasks/:task_id/streamevent: progress
data: {"task_id":"vid_01HXY...","status":"running","progress":12}
event: progress
data: {"task_id":"vid_01HXY...","status":"running","progress":58}
event: completed
data: {"task_id":"vid_01HXY...","status":"completed","progress":100,"result_url":"https://cdn.api.airforce/video/vid_01HXY....mp4"}3. Liệt kê và xóa
https://api.airforce/v1/video/tasksTrả về các tác vụ gần đây của bạn (mới nhất trước). Hữu ích cho bảng điều khiển để hiển thị chế độ xem lịch sử.
| Parameter | Type | Required | Description |
|---|---|---|---|
| limit | integer | Optional | Max items returned. Default 50, max 200. Pass as a query string. |
| status | string | Optional | Filter to one status, e.g. ?status=running. |
curl "https://api.airforce/v1/video/tasks?limit=20&status=completed" \
-H "Authorization: Bearer sk-air-YOUR_API_KEY"https://api.airforce/v1/video/tasks/:task_idXóa nhiệm vụ khỏi lịch sử của bạn. MP4 cũng bị xóa khỏi bộ lưu trữ CDN. Không hoàn lại tiền - chi phí đã được ghi nợ.
Chi phí & hạn chế
Mỗi mô hình video hiển thị siêu dữ liệu về khả năng mà bạn có thể đọc từ đó /v1/models:
| Parameter | Type | Required | Description |
|---|---|---|---|
| video_caps.aspect_ratios | array | Optional | Allowed aspect_ratio values. |
| video_caps.qualities | array | Optional | Allowed quality values. |
| video_caps.min_duration_s / max_duration_s | integer | Optional | Allowed range for duration_seconds. |
| video_caps.modes | array | Optional | Subset of ["text", "image", "reference"] supported. |
| video_caps.price_per_second_cents | integer | Optional | Cost = duration_seconds × this value. |
- Cost is debited at task creation. Failed tasks (status "failed" or "expired") refund the cost.
- Max 4 concurrent video tasks per API key.
- Result URLs are pre-signed and stop working at
expires_at. Download or copy the MP4 to your own storage if you need it longer.
Kịch bản đầu cuối
async function generateVideo(prompt) {
const create = await fetch('https://api.airforce/v1/video/generations', {
method: 'POST',
headers: {
Authorization: `Bearer ${API_KEY}`,
'Content-Type': 'application/json',
},
body: JSON.stringify({
model: 'wan-2.6',
prompt,
duration_seconds: 8,
aspect_ratio: '16:9',
quality: '720p',
}),
}).then(r => r.json());
const { task_id } = create;
// Poll until done.
while (true) {
await new Promise(r => setTimeout(r, 8_000));
const task = await fetch(
`https://api.airforce/v1/video/tasks/${task_id}`,
{ headers: { Authorization: `Bearer ${API_KEY}` } },
).then(r => r.json());
if (task.status === 'completed') return task.result_url;
if (task.status === 'failed' || task.status === 'expired') {
throw new Error(task.error?.message ?? task.status);
}
}
}