Перейти к основному содержанию
POST
/
v1
/
seedance2
/
real-avatar
curl --request POST \
  --url https://api.apimart.ai/v1/seedance2/real-avatar \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "callback_url": "https://example.com/callback",
    "project_name": "default"
  }'
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "completed"
  }
}

Documentation Index

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

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

curl --request POST \
  --url https://api.apimart.ai/v1/seedance2/real-avatar \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "callback_url": "https://example.com/callback",
    "project_name": "default"
  }'
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "completed"
  }
}

Аутентификация

Authorization
string
обязательно
Все запросы требуют аутентификации через Bearer TokenПолучите ваш API Key:Перейдите на страницу управления API Key, чтобы получить ваш API KeyДобавьте следующий заголовок к каждому запросу:
Authorization: Bearer YOUR_API_KEY

Параметры запроса

Шаг 1: создание сессии верификации реального человека

callback_url
string
обязательно
URL обратного вызова после завершения верификацииСистема отправит уведомление на этот адрес, как только пользователь завершит H5-верификацию
project_name
string
по умолчанию:"default"
Имя проектаПо умолчанию: default

Ответ

code
integer
Код состояния ответа, 200 при успехе
data
object
Информация о задаче
Запросите задачу, чтобы получить ссылку H5-верификации:
GET /v1/tasks/task_01K...
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "completed",
    "result": {
      "byted_token": "token_xxx",
      "h5_link": "https://...",
      "raw_response": {}
    }
  }
}

Шаг 2: запрос результата верификации реального человека

byted_token
string
обязательно
Токен аутентификации, полученный из результата задачи шага 1После того как пользователь завершит H5-верификацию, запросите задачу через GET /v1/tasks/{id}, чтобы получить byted_token, а затем используйте его здесь для получения результата верификации и GroupId группы ассетов реальных людей
project_name
string
по умолчанию:"default"
Имя проектаПо умолчанию: default

Шаг 3: пакетная отправка ассетов реальных людей

group_id
string
обязательно
ID группы ассетов реальных людейЗначение GroupId, полученное из результата верификации на шаге 2
project_name
string
по умолчанию:"default"
Имя проектаПо умолчанию: default
asset_type
string
по умолчанию:"Video"
Тип ассетаВарианты:
  • Video — видеоассет (по умолчанию, рекомендуется для портретов реальных людей)
  • Image — графический ассет
По умолчанию: Video
assets
array
обязательно
Список ассетов, поддерживает отправку нескольких ассетов в одном запросеПример:
{
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    },
    {
      "url": "https://example.com/avatar-b.png",
      "name": "avatar-b"
    }
  ]
}

Ответ

code
integer
Код состояния ответа, 200 при успехе
data
object
Информация о задаче модерации ассетов

Запрос результата модерации

Отправка ассетов — это асинхронная задача. Используйте эндпоинт Получение статуса задачи для отслеживания:

Все одобрены

{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "completed",
    "progress": 100,
    "result": {
      "assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        },
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Active"
        }
      ],
      "usable_assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        },
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Active"
        }
      ],
      "failed_assets": []
    }
  }
}

Частичный сбой

{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "failed",
    "progress": 100,
    "result": {
      "assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        },
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Failed"
        }
      ],
      "usable_assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        }
      ],
      "failed_assets": [
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Failed"
        }
      ]
    },
    "error": {
      "code": "task_failed",
      "message": "Some assets failed review"
    }
  }
}
  • result.usable_assets[].asset_url можно напрямую использовать при генерации видео Seedance 2.0
  • Ассеты в result.failed_assets должны быть заменены или отправлены повторно

Использование одобренных ассетов

Передайте URL asset://... напрямую в эндпоинт Генерация видео Seedance 2.0:
{
  "model": "doubao-seedance-2.0-face",
  "prompt": "Generate a video using the reference portrait",
  "image_with_roles": [
    {
      "url": "asset://asset_a",
      "role": "reference_image"
    }
  ]
}
  • Ассеты аватаров реальных людей рекомендуется использовать с моделями doubao-seedance-2.0-face или doubao-seedance-2.0-fast-face
  • Как только сервер обнаруживает префикс asset://, он отправляет задачу генерации напрямую, не запуская повторную модерацию ассета