Creative Lab — キーチェーン API

ソース写真を、3Dプリント可能なキーチェーンメダリオン(バッジ形状の カラー化された深度レリーフ)へ、2段階で変換します。prototype は入力写真からカラー化された コンセプト画像を生成し、その後 build がそのコンセプト画像を レリーフ 3D モデルに変換します。2つの段階は input_task_id を介して関連付けられます。

  • POST /openapi/creative-lab/keychain/v1/prototype
  • POST /openapi/creative-lab/keychain/v1/build

POST/openapi/creative-lab/keychain/v1/prototype

キーチェーンのプロトタイプタスクを作成

ソース写真から、カラー化された単一のコンセプト画像を生成します。 返されたタスク ID は、build endpoint に input_task_id として渡します。レスポンスの形式については キーチェーンプロトタイプタスクオブジェクト を参照してください。

パラメータ

  • Name
    image_url
    Type
    string
    必須
    Description

    Meshy がキーチェーン用のコンセプト画像としてカラー化するためのソース写真です。現在、.jpg.jpeg.png.webp 形式をサポートしています。

    画像を提供する方法は 2 つあります。

    • 公開アクセス可能な URL: 公開インターネットからアクセス可能な URL。
    • Data URI: 画像の base64 エンコードされたデータ URI。データ URI の例: data:image/jpeg;base64,<your base64-encoded image data>
  • Name
    name
    Type
    string
    Description

    表示用の任意のタスク名。最大 100 文字です。

戻り値

レスポンスの result プロパティには、新しく作成されたキーチェーンプロトタイプタスクのタスク id が含まれます。タスクが SUCCEEDED に到達するまで タスクを取得 endpoint をポーリングするか、stream を購読し、その ID を build endpointinput_task_id として渡してください。

失敗モード

  • Name
    400 - Bad Request
    Description

    リクエストは受け付けられませんでした。一般的な原因:

    • パラメータ不足: image_url は必須です。
    • 無効な画像形式: 提供された image_url はサポートされている形式(.jpg.jpeg.png.webp)ではありません。
    • 画像サイズが範囲外: 画像が小さすぎる、最大ファイルサイズを超えている、または最大ピクセル数を超えています。
    • 到達不能な URL: image_url をダウンロードできませんでした(404 またはタイムアウト)。
    • 無効な Data URI: base64 文字列の形式が正しくありません。
    • フラグ付けされたコンテンツ: 入力画像が NSFW または知的財産のモデレーションによってフラグ付けされました。
  • Name
    401 - Unauthorized
    Description

    認証に失敗しました。API key を確認してください。

  • Name
    402 - Payment Required
    Description

    このタスクを実行するためのクレジットが不足しています。

  • Name
    429 - Too Many Requests
    Description

    レート制限を超過しました。

Request

POST
/openapi/creative-lab/keychain/v1/prototype
# Stage 1: generate a colorized keychain concept image
curl https://api.meshy.ai/openapi/creative-lab/keychain/v1/prototype \
  -X POST \
  -H "Authorization: Bearer ${YOUR_API_KEY}" \
  -H 'Content-Type: application/json' \
  -d '{
    "image_url": "<your publicly accessible image url or base64-encoded data URI>"
  }'

Response

{
  "result": "018a210d-8ba4-705c-b111-1f1776f7f578"
}
プロトタイプの例
ソース写真から開始し、キーチェーンのビルド段階で使用するプロトタイプ画像を生成します。
Creative Lab Keychain の入力として使用されるソース写真
プロトタイプ入力
ソース写真から生成された Creative Lab Keychain のプロトタイプ出力
プロトタイプ出力


POST/openapi/creative-lab/keychain/v1/build

キーチェーンビルドタスクを作成

成功したプロトタイプタスクから、最終的な3Dプリント可能なキーチェーンメダリオンを生成します。ビルドは、プロトタイプのカラー化されたコンセプト画像に対して深度マップのレリーフパイプラインを実行し、指定した形式で単一のメッシュアーティファクトを提供します。レスポンス形式については、 キーチェーンビルドタスクオブジェクト を参照してください。

パラメータ

  • Name
    input_task_id
    Type
    string
    必須
    Description

    この同じOpenAPI endpointを介して作成されたプロトタイプタスクのタスクIDです。プロトタイプは同じAPI keyで作成されている必要があり、SUCCEEDED に到達していて、かつ候補画像を正確に1つ生成している必要があります。

    Webアプリから作成されたプロトタイプタスクは受け付けられません — ビルドendpointは POST /openapi/creative-lab/keychain/v1/prototype によって生成されたプロトタイプタスクのみを受け付け、それ以外のソースは 404 で拒否します。

  • Name
    name
    Type
    string
    Description

    表示用の任意のタスク名です。最大100文字です。

options

レリーフジオメトリ用の任意の調整パラメータです。すべてのフィールドには適切なデフォルト値があります — 上書きしたいものだけを送信してください。

  • Name
    badge_shape
    Type
    string
    デフォルト circle
    Description

    キーチェーンメダリオンの外形シルエットです。利用可能な値:

    • circle(デフォルト)
    • rounded-rect
    • hexagon
    • shield
    • star
  • Name
    size_mm
    Type
    number
    デフォルト 40
    Description

    キーチェーンの外接正方形の辺の長さ(ミリメートル)です。範囲: (0, 400]

  • Name
    relief_height_mm
    Type
    number
    デフォルト 2.2
    Description

    ベース上の最大レリーフ高さ(ミリメートル)です。範囲: [0, 20]

  • Name
    relief_offset_mm
    Type
    number
    デフォルト 0
    Description

    押し出し前にレリーフへ適用される垂直オフセット(ミリメートル)です。範囲: [0, 20]

  • Name
    base_thickness_mm
    Type
    number
    デフォルト 0.1
    Description

    レリーフの背面にある平坦なベースプレートの厚さ(ミリメートル)です。範囲: [0, 20]

  • Name
    has_closed_back
    Type
    boolean
    デフォルト true
    Description

    メダリオンの背面を閉じたサーフェスとして封止するかどうかです。開いたシェルにするには false に設定します。

  • Name
    relief_curve
    Type
    string
    デフォルト linear
    Description

    深度マップ値をレリーフ高さへマッピングする転送曲線です。利用可能な値:

    • linear(デフォルト)
    • gamma
    • s-curve
  • Name
    curve_param
    Type
    number
    デフォルト 1.0
    Description

    転送曲線の形状パラメータです(relief_curvegamma の場合にのみ意味があります)。範囲: (0, 10]

  • Name
    invert_depth
    Type
    boolean
    デフォルト false
    Description

    深度マップの解釈を反転し、暗い領域がより高いレリーフになるようにします。

  • Name
    smoothing
    Type
    number
    デフォルト 0.24
    Description

    レリーフ抽出前に深度マップへ適用されるスムージング強度です。範囲: [0, 10]

  • Name
    relief_scale
    Type
    number
    デフォルト 1.0
    Description

    relief_height_mm の上に適用される垂直スケール倍率です。範囲: (0, 10]

  • Name
    depth_threshold
    Type
    number
    デフォルト 0.1
    Description

    深度マップ値のローパスしきい値です。これを下回る値はすべてゼロにクランプされます。範囲: [0, 1]

  • Name
    remove_background
    Type
    boolean
    デフォルト true
    Description

    レリーフ化の前に、プロトタイプのコンセプト画像の背景を自動的に削除します。

  • Name
    export_resolution
    Type
    integer
    デフォルト 512
    Description

    エクスポートに使用されるメッシュ解像度です。範囲: [64, 2048]

output

任意のワイヤーフォーマットセレクタです。デフォルトは glb です。

  • Name
    format
    Type
    string
    デフォルト glb
    Description

    ビルドによって返されるアーティファクトバンドルです。利用可能な値:

    • glb(デフォルト)— model_urls.glb の下に単一の model.glb を返します。
    • objmodel.obj + model.mtl + texture.png をzip化し、model_urls.obj の下にバンドルを返します。
    • zip — ジェネレーターが出力するすべてのアーティファクトをzip化し、model_urls.bundle_zip の下にバンドルを返します。

戻り値

レスポンスの result プロパティには、新しく作成されたキーチェーンビルドタスクのタスク id が含まれます。タスクが SUCCEEDED に到達するまで タスクを取得 endpointをポーリングするか、stream を購読し、その後 model_urls 内の単一のエントリからアーティファクトをダウンロードしてください。

失敗モード

  • Name
    400 - Bad Request
    Description

    リクエストは受け入れられませんでした。一般的な原因:

    • パラメータ不足: input_task_id は必須です。
    • 無効なUUID: input_task_id が有効なUUIDではありません。
    • 親が成功していない: 参照されたプロトタイプタスクがまだ SUCCEEDED に到達していません。
    • 候補なし: プロトタイプタスクは成功しましたが、候補画像を生成しませんでした。
    • オプションが範囲外: options フィールドのいずれかが許可された範囲または列挙セットの外にあります。
  • Name
    401 - Unauthorized
    Description

    認証に失敗しました。API keyを確認してください。

  • Name
    402 - Payment Required
    Description

    このタスクを実行するためのクレジットが不足しています。

  • Name
    404 - Not Found
    Description

    参照されたプロトタイプタスクが存在しない、別のユーザーに属している、またはWebアプリから作成されています(APIモードのプロトタイプタスクのみがビルドへ連鎖できます)。

  • Name
    429 - Too Many Requests
    Description

    レート制限を超過しました。

Request

POST
/openapi/creative-lab/keychain/v1/build
# Stage 2: chain build off a succeeded prototype task
curl https://api.meshy.ai/openapi/creative-lab/keychain/v1/build \
  -X POST \
  -H "Authorization: Bearer ${YOUR_API_KEY}" \
  -H 'Content-Type: application/json' \
  -d '{
    "input_task_id": "018a210d-8ba4-705c-b111-1f1776f7f578",
    "options": {
      "badge_shape": "circle",
      "size_mm": 40,
      "relief_height_mm": 2.5
    },
    "output": {
      "format": "glb"
    }
  }'

Response

{
  "result": "019c320e-9a8f-7a1c-9c11-2a1876f8a9bb"
}
Build example
The build task converts the selected prototype image into a 3D-printable keychain model.
Creative Lab Keychain build model preview
Build model preview

GET/openapi/creative-lab/keychain/v1/(prototype|build)/:id

Keychain タスクを取得する

有効なタスク id を指定して、prototype または build タスクを取得します。URL パスは タスクのステージと一致している必要があります — build タスクを /prototype/:id から取得すると 404 が返され、その逆も同様です。

レスポンスの形状については、Keychain Prototype タスクオブジェクト および Keychain Build タスクオブジェクト を 参照してください。

パラメーター

  • Name
    id
    Type
    path
    Description

    取得する keychain タスクの一意の識別子。

戻り値

レスポンスには keychain タスクオブジェクトが含まれます。形状はリクエストされた ステージによって異なります。

Request

GET
/openapi/creative-lab/keychain/v1/prototype/018a210d-8ba4-705c-b111-1f1776f7f578
# Prototype
curl https://api.meshy.ai/openapi/creative-lab/keychain/v1/prototype/018a210d-8ba4-705c-b111-1f1776f7f578 \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

# Build
curl https://api.meshy.ai/openapi/creative-lab/keychain/v1/build/019c320e-9a8f-7a1c-9c11-2a1876f8a9bb \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

Prototype Response

{
  "id": "018a210d-8ba4-705c-b111-1f1776f7f578",
  "type": "creative-lab-keychain-prototype",
  "name": "",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1729123456000,
  "started_at": 1729123460000,
  "finished_at": 1729123486000,
  "expires_at": 1729382686000,
  "preceding_tasks": 0,
  "task_error": null,
  "consumed_credits": 6,
  "image_urls": [
    "https://assets.meshy.ai/***/concept.png?Expires=***"
  ]
}

Build Response

{
  "id": "019c320e-9a8f-7a1c-9c11-2a1876f8a9bb",
  "type": "creative-lab-keychain-build",
  "name": "",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1729123500000,
  "started_at": 1729123510000,
  "finished_at": 1729123535000,
  "expires_at": 1729382735000,
  "preceding_tasks": 0,
  "task_error": null,
  "consumed_credits": 20,
  "model_urls": {
    "glb": "https://assets.meshy.ai/***/tasks/019c320e-9a8f-7a1c-9c11-2a1876f8a9bb/output/model.glb?Expires=***"
  }
}

DELETE/openapi/creative-lab/keychain/v1/(prototype|build)/:id

キーチェーンタスクを削除

キーチェーンタスクをキャンセルします。タスクがまだ PENDING の場合、作成時に消費されたクレジットは返還されます。すでに IN_PROGRESS のタスクは返還なしでキャンセルされます(ワーカーがすでにリソースを 消費している可能性があります)。すでに終端状態 (SUCCEEDEDFAILEDCANCELED)に到達したタスクはキャンセルできません。

URL パスはタスクのステージと一致している必要があります — /prototype/:buildId に対する DELETE404 を返します。

パスパラメータ

  • Name
    id
    Type
    path
    Description

    キャンセルするキーチェーンタスクの一意の識別子。

戻り値

成功時は空のボディで 204 No Content を返します。

失敗モード

  • Name
    400 - Bad Request
    Description

    タスクはすでに終端状態であり、キャンセルできません。

  • Name
    404 - Not Found
    Description

    タスクが存在しない、別のユーザーに属している、またはそのステージが URL パスと一致しません。

Request

DELETE
/openapi/creative-lab/keychain/v1/prototype/018a210d-8ba4-705c-b111-1f1776f7f578
curl --request DELETE \
  --url https://api.meshy.ai/openapi/creative-lab/keychain/v1/prototype/018a210d-8ba4-705c-b111-1f1776f7f578 \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

Response

// Returns 204 No Content on success (empty body).

GET/openapi/creative-lab/keychain/v1/(prototype|build)/:id/stream

Keychainタスクをストリーミングする

Server-Sent Events (SSE) 経由で、Keychainタスクのリアルタイム更新をストリーミングします。 URLパスはタスクのステージと一致している必要があります — /prototype/:buildId/stream でストリームを開くと、status_code: 404 を含む単一の event: error ペイロードが送信され、ストリームが閉じられます。

パラメーター

  • Name
    id
    Type
    path
    Description

    ストリーミングするKeychainタスクの一意の識別子。

戻り値

Keychain Prototype または Keychain Build タスクオブジェクトのストリームを Server-Sent Eventsとして返します。PENDING または IN_PROGRESS タスクの場合、レスポンス ストリームには必要な progress および status フィールドのみが含まれます。

Request

GET
/openapi/creative-lab/keychain/v1/build/019c320e-9a8f-7a1c-9c11-2a1876f8a9bb/stream
curl -N https://api.meshy.ai/openapi/creative-lab/keychain/v1/build/019c320e-9a8f-7a1c-9c11-2a1876f8a9bb/stream \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response Stream

// Error event example (wrong stage or task not found)
event: error
data: {
  "status_code": 404,
  "message": "Task not found"
}

// Message event examples illustrate task progress.
// For PENDING or IN_PROGRESS tasks, the response stream will not include all fields.
event: message
data: {
  "id": "019c320e-9a8f-7a1c-9c11-2a1876f8a9bb",
  "progress": 0,
  "status": "PENDING"
}

event: message
data: {
  "id": "019c320e-9a8f-7a1c-9c11-2a1876f8a9bb",
  "type": "creative-lab-keychain-build",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1729123500000,
  "started_at": 1729123510000,
  "finished_at": 1729123535000,
  "expires_at": 1729382735000,
  "task_error": null,
  "consumed_credits": 20,
  "model_urls": {
    "glb": "https://assets.meshy.ai/***/tasks/019c320e-9a8f-7a1c-9c11-2a1876f8a9bb/output/model.glb?Expires=***"
  }
}

GET/openapi/creative-lab/keychain/v1/(prototype|build)

キーチェーンタスクの一覧取得

単一ステージのキーチェーンタスクのページ分割された一覧を取得します。URL パスでステージを選択します — /prototype はプロトタイプタスクを返し、/build はビルドタスクを返します。もう一方のステージのタスクは、どちらの レスポンスにも含まれません。

パスパラメータ

  • Name
    stage
    Type
    path
    必須
    Description

    prototype または build のいずれかです。このコレクションは、URL と ステージが一致するタスクのみを返します — /prototype の取得で ビルドタスクが返されることはなく、その逆も同様です。

クエリパラメータ

  • Name
    page_num
    Type
    integer
    デフォルト 1
    Description

    ページネーション用のページ番号。

  • Name
    page_size
    Type
    integer
    デフォルト 10
    Description

    ページサイズの上限。許可される最大値は 50 件です。

  • Name
    sort_by
    Type
    string
    デフォルト -created_at
    Description

    ソート対象のフィールド。利用可能な値:

    • +created_at: 作成時刻の昇順でソートします。
    • -created_at: 作成時刻の降順でソートします。

戻り値

ステージごとのタスクオブジェクトのページ分割された一覧を返します — /prototype を一覧取得する場合は キーチェーンプロトタイプタスクオブジェクト/build を一覧取得する場合は キーチェーンビルドタスクオブジェクト です。

Request

GET
/openapi/creative-lab/keychain/v1/prototype
# List prototype tasks
curl https://api.meshy.ai/openapi/creative-lab/keychain/v1/prototype?page_size=10 \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

# List build tasks
curl https://api.meshy.ai/openapi/creative-lab/keychain/v1/build?page_size=10 \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

Response (List Prototype Tasks)

[
  {
    "id": "018a210d-8ba4-705c-b111-1f1776f7f578",
    "type": "creative-lab-keychain-prototype",
    "name": "",
    "status": "SUCCEEDED",
    "progress": 100,
    "created_at": 1729123456000,
    "started_at": 1729123460000,
    "finished_at": 1729123486000,
    "expires_at": 1729382686000,
    "preceding_tasks": 0,
    "task_error": null,
    "consumed_credits": 6,
    "image_urls": [
      "https://assets.meshy.ai/***/concept.png?Expires=***"
    ]
  }
]

キーチェーンプロトタイプタスクオブジェクト

キーチェーンプロトタイプタスクオブジェクトは、ソース写真からカラー化されたコンセプト画像を生成するために Meshy が追跡する作業単位です。このステージの出力は、input_task_id を介してビルドステージに連結されます。

プロパティ

  • Name
    id
    Type
    string
    Description

    タスクの一意の識別子です。実装の詳細としてタスク ID には k-sortable UUID を使用していますが、id の形式についてはいかなる仮定も行わないでください

  • Name
    type
    Type
    string
    Description

    タスクの種類です。値は creative-lab-keychain-prototype です。

  • Name
    name
    Type
    string
    Description

    タスク作成時に指定されたタスク名です。名前が指定されていない場合は空文字列です。

  • Name
    status
    Type
    string
    Description

    タスクのステータスです。可能な値は PENDINGIN_PROGRESSSUCCEEDEDFAILEDCANCELED のいずれかです。

  • Name
    progress
    Type
    integer
    Description

    タスクの進行状況です。タスクがまだ開始されていない場合、このプロパティは 0 になります。タスクが成功すると、これは 100 になります。

  • Name
    created_at
    Type
    timestamp
    Description

    タスクが作成された時刻のタイムスタンプ(ミリ秒)です。

  • Name
    started_at
    Type
    timestamp
    Description

    タスクが開始された時刻のタイムスタンプ(ミリ秒)です。タスクがまだ開始されていない場合、このプロパティは 0 になります。

  • Name
    finished_at
    Type
    timestamp
    Description

    タスクが完了した時刻のタイムスタンプ(ミリ秒)です。タスクがまだ完了していない場合、このプロパティは 0 になります。

  • Name
    expires_at
    Type
    timestamp
    Description

    タスク結果の有効期限のタイムスタンプ(ミリ秒)です。

  • Name
    preceding_tasks
    Type
    integer
    Description

    先行タスクの数です。

  • Name
    task_error
    Type
    object
    Description

    失敗したタスクのエラー詳細です。完全な task_error オブジェクトのリファレンスについては、Errors を参照してください。

  • Name
    consumed_credits
    Type
    integer
    Description

    このタスクによって消費されたクレジットの数です。タスクのステータスが PENDINGIN_PROGRESS、または SUCCEEDED の場合に存在します。FAILED タスクの場合は 0 を返します(失敗時にはクレジットが返還されます)。

  • Name
    image_urls
    Type
    array of strings
    Description

    このプロトタイプタスクによって生成されたコンセプト画像候補のダウンロード可能な URL です。現在、API は常に候補を 1 つだけ返します。このフィールドは配列であるため、将来の改訂で破壊的変更なしに複数の候補を提供できます。

Example Keychain Prototype Task Object

{
  "id": "018a210d-8ba4-705c-b111-1f1776f7f578",
  "type": "creative-lab-keychain-prototype",
  "name": "",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1729123456000,
  "started_at": 1729123460000,
  "finished_at": 1729123486000,
  "expires_at": 1729382686000,
  "preceding_tasks": 0,
  "task_error": null,
  "consumed_credits": 6,
  "image_urls": [
    "https://assets.meshy.ai/***/concept.png?Expires=***"
  ]
}

キーチェーンビルドタスクオブジェクト

キーチェーンビルドタスクオブジェクトは、成功したプロトタイプタスクから最終的な3Dキーチェーンメッシュを 生成するためにMeshyが追跡する作業単位です。 ビルドはプロトタイプのコンセプト画像に対して深度マップレリーフパイプラインを実行し、 呼び出し元が要求した形式で単一のメッシュアーティファクトを公開します。

プロパティ

  • Name
    id
    Type
    string
    Description

    タスクの一意の識別子。

  • Name
    type
    Type
    string
    Description

    タスクの種類。値は creative-lab-keychain-build です。

  • Name
    name
    Type
    string
    Description

    タスク作成時に指定されたタスク名。名前が指定されていない場合は空文字列です。

  • Name
    status
    Type
    string
    Description

    タスクのステータス。指定可能な値は PENDINGIN_PROGRESSSUCCEEDEDFAILEDCANCELED のいずれかです。

  • Name
    progress
    Type
    integer
    Description

    タスクの進行状況。タスクがまだ開始されていない場合、このプロパティは 0 になります。タスクが成功すると、100 になります。

  • Name
    created_at
    Type
    timestamp
    Description

    タスクが作成された日時のタイムスタンプ(ミリ秒)。

  • Name
    started_at
    Type
    timestamp
    Description

    タスクが開始された日時のタイムスタンプ(ミリ秒)。

  • Name
    finished_at
    Type
    timestamp
    Description

    タスクが完了した日時のタイムスタンプ(ミリ秒)。

  • Name
    expires_at
    Type
    timestamp
    Description

    タスク結果の有効期限が切れる日時のタイムスタンプ(ミリ秒)。

  • Name
    preceding_tasks
    Type
    integer
    Description

    先行タスクの数。ステータスが PENDING の場合にのみ意味があります。

  • Name
    task_error
    Type
    object
    Description

    失敗したタスクのエラー詳細。完全な task_error オブジェクトのリファレンスについては、エラー を参照してください。

  • Name
    consumed_credits
    Type
    integer
    Description

    このタスクで消費されたクレジット数。FAILED タスクの場合は 0 を返します(失敗時にクレジットは返却されます)。

  • Name
    model_urls
    Type
    object
    Description

    生成されたアーティファクトのダウンロード可能な URL。アーティファクト名をキーとします。常に正確に 1 つのエントリを含みます — ビルドリクエストの output.format で要求された形式です。キーは要求された形式と一致します。

    • Name
      glb
      Type
      string
      Description

      GLB ファイルへのダウンロード可能な URL。output.formatglb(デフォルト)の場合に存在します。

    • Name
      obj
      Type
      string
      Description

      model.objmodel.mtltexture.png を含む zip バンドルへのダウンロード可能な URL。output.formatobj の場合に存在します。

    • Name
      bundle_zip
      Type
      string
      Description

      ジェネレーターが出力するすべてのアーティファクトの zip バンドルへのダウンロード可能な URL。output.formatzip の場合に存在します。

Example Keychain Build Task Object

{
  "id": "019c320e-9a8f-7a1c-9c11-2a1876f8a9bb",
  "type": "creative-lab-keychain-build",
  "name": "",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1729123500000,
  "started_at": 1729123510000,
  "finished_at": 1729123535000,
  "expires_at": 1729382735000,
  "preceding_tasks": 0,
  "task_error": null,
  "consumed_credits": 20,
  "model_urls": {
    "glb": "https://assets.meshy.ai/***/tasks/019c320e-9a8f-7a1c-9c11-2a1876f8a9bb/output/model.glb?Expires=***"
  }
}