Saltar para o conteúdo principal
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"
  }
}

Autenticação

Authorization
string
obrigatório
Todas as requisições exigem autenticação via Bearer TokenObtenha sua API Key:Acesse a página de gerenciamento de API Keys para obter sua API KeyAdicione o seguinte cabeçalho a cada requisição:
Authorization: Bearer YOUR_API_KEY

Parâmetros da requisição

Etapa 1: Criar sessão de verificação de pessoa real

callback_url
string
obrigatório
URL de callback após a conclusão da verificaçãoO sistema envia uma notificação de callback para este endereço assim que o usuário conclui a verificação H5
project_name
string
padrão:"default"
Nome do projetoPadrão: default

Resposta

code
integer
Código de status da resposta, 200 em caso de sucesso
data
object
Informações da tarefa
Consulte a tarefa para obter o link de verificação H5:
GET /v1/tasks/task_01K...
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "completed",
    "result": {
      "byted_token": "token_xxx",
      "h5_link": "https://...",
      "raw_response": {}
    }
  }
}

Etapa 2: Consultar resultado da verificação de pessoa real

byted_token
string
obrigatório
Token de autenticação obtido a partir do resultado da tarefa da Etapa 1Depois que o usuário concluir a verificação H5, consulte a tarefa via GET /v1/tasks/{id} para obter byted_token e, então, use-o aqui para recuperar o resultado da verificação e o GroupId do grupo de assets de pessoa real
project_name
string
padrão:"default"
Nome do projetoPadrão: default

Etapa 3: Envio em lote de assets de pessoa real

group_id
string
obrigatório
ID do grupo de assets de pessoa realO GroupId obtido a partir do resultado da verificação da Etapa 2
project_name
string
padrão:"default"
Nome do projetoPadrão: default
asset_type
string
padrão:"Video"
Tipo de assetOpções:
  • Video — asset de vídeo (padrão, recomendado para retratos de pessoa real)
  • Image — asset de imagem
Padrão: Video
assets
array
obrigatório
Lista de assets, permite enviar múltiplos assets em uma única requisiçãoExemplo:
{
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    },
    {
      "url": "https://example.com/avatar-b.png",
      "name": "avatar-b"
    }
  ]
}

Resposta

code
integer
Código de status da resposta, 200 em caso de sucesso
data
object
Informações da tarefa de revisão de assets

Consultar resultado da revisão

A submissão de assets é uma tarefa assíncrona. Use o endpoint Obter status da tarefa para fazer polling:

Todos aprovados

{
  "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": []
    }
  }
}

Falha parcial

{
  "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 pode ser usado diretamente na geração de vídeo Seedance 2.0
  • Os assets em result.failed_assets devem ser substituídos ou reenviados

Usando assets aprovados

Passe a URL asset://... diretamente para o endpoint de Geração de vídeo 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"
    }
  ]
}
  • Recomenda-se que os assets de avatar de pessoa real sejam usados com os modelos doubao-seedance-2.0-face ou doubao-seedance-2.0-fast-face
  • Assim que o servidor detecta o prefixo asset://, ele envia a tarefa de geração diretamente, sem acionar outra revisão do asset