Passer au contenu principal
POST
/
v1
/
seedance2
/
private-avatar
curl --request POST \
  --url https://api.apimart.ai/v1/seedance2/private-avatar \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "group": {
      "name": "virtual-avatar-group",
      "description": "demo group"
    },
    "project_name": "default",
    "asset_type": "Image",
    "assets": [
      {
        "url": "https://example.com/avatar-a.png",
        "name": "avatar-a"
      },
      {
        "url": "https://example.com/avatar-b.png",
        "name": "avatar-b"
      }
    ]
  }'
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "object": "seedance.avatar.asset.task",
    "status": "processing",
    "progress": 10,
    "model": "doubao-seedance-2.0"
  }
}

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/private-avatar \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "group": {
      "name": "virtual-avatar-group",
      "description": "demo group"
    },
    "project_name": "default",
    "asset_type": "Image",
    "assets": [
      {
        "url": "https://example.com/avatar-a.png",
        "name": "avatar-a"
      },
      {
        "url": "https://example.com/avatar-b.png",
        "name": "avatar-b"
      }
    ]
  }'
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "object": "seedance.avatar.asset.task",
    "status": "processing",
    "progress": 10,
    "model": "doubao-seedance-2.0"
  }
}

Authentification

Authorization
string
requis
Toutes les requêtes nécessitent une authentification par Bearer TokenObtenez votre API Key :Rendez-vous sur la page de gestion des API Keys pour obtenir votre API KeyAjoutez l’en-tête suivant à chaque requête :
Authorization: Bearer YOUR_API_KEY

Paramètres de la requête

group
object
Informations sur le groupe d’assetsSi group_id n’est pas fourni, le serveur crée automatiquement un groupe d’assets AIGC à partir de ce champExemple :
{
  "group": {
    "name": "virtual-avatar-group",
    "description": "demo group"
  }
}
Mutuellement exclusif avec group_id — ne fournissez pas les deux en même temps
group_id
string
ID d’un groupe d’assets existantLorsqu’il est fourni, la création du groupe est ignorée et les assets sont envoyés directement vers le groupe indiqué
Mutuellement exclusif avec group — ne fournissez pas les deux en même temps
project_name
string
défaut:"default"
Nom du projetPar défaut : default
asset_type
string
défaut:"Image"
Type d’assetOptions :
  • Image — asset image (par défaut)
  • Video — asset vidéo
  • Audio — asset audio
Par défaut : Image
assets
array
Liste d’assets, prend en charge la soumission de plusieurs assets en une seule requête
Maximum de 20 assets par soumission
Exemple :
{
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    },
    {
      "url": "https://example.com/avatar-b.png",
      "name": "avatar-b"
    }
  ]
}
url
string
Forme abrégée pour un asset unique : URL de l’asset
Utilisez soit le tableau assets, soit ce champ — pas les deux. Adapté à la soumission d’un asset unique.
name
string
Forme abrégée pour un asset unique : nom de l’asset
Utilisez soit le tableau assets, soit ce champ — pas les deux. Adapté à la soumission d’un asset unique.

Réponse

code
integer
Code d’état de la réponse, 200 en cas de succès
data
object
Informations sur la tâche

Exemples

Exemple 1 : soumission en lot (création automatique de groupe)

Lorsque group_id n’est pas fourni, le serveur crée automatiquement un groupe d’assets AIGC avant la soumission.
{
  "group": {
    "name": "virtual-avatar-group",
    "description": "demo group"
  },
  "project_name": "default",
  "asset_type": "Image",
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    },
    {
      "url": "https://example.com/avatar-b.png",
      "name": "avatar-b"
    }
  ]
}

Exemple 2 : ajouter des assets à un groupe existant

Fournissez group_id pour ignorer la création du groupe et soumettre directement.
{
  "group_id": "group_xxx",
  "project_name": "default",
  "asset_type": "Image",
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    }
  ]
}

Exemple 3 : forme abrégée pour un asset unique

Pour un asset unique, utilisez directement les champs url et name de premier niveau.
{
  "group_id": "group_xxx",
  "url": "https://example.com/avatar.png",
  "asset_type": "Image",
  "name": "avatar-1"
}

Interroger le résultat de validation

La soumission d’assets est une tâche asynchrone. Utilisez le point de terminaison Obtenir le statut de la tâche pour effectuer le suivi :
GET /v1/tasks/{id}

Tous approuvés

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

Échec partiel

Si certains assets n’ont pas réussi la validation, le statut de la tâche devient failed. Les assets approuvés avec succès restent utilisables et apparaissent dans result.usable_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 peut être utilisé directement dans la génération vidéo Seedance 2.0
  • Les assets de result.failed_assets doivent être remplacés ou resoumis
  • Les tâches portant sur un seul asset renvoient également result.asset_url pour des raisons de compatibilité

Utilisation des assets approuvés

Transmettez l’URL asset://... directement au point de terminaison Génération vidéo Seedance 2.0 :
{
  "model": "doubao-seedance-2.0",
  "prompt": "The character walks naturally along a city street",
  "image_urls": ["asset://asset_a"],
  "duration": 5,
  "resolution": "720p"
}
Dès que le serveur détecte le préfixe asset://, il soumet la tâche de génération directement sans déclencher de nouvelle validation d’asset.