> ## Documentation Index
> Fetch the complete documentation index at: https://docs.jimmyai.cn/llms.txt
> Use this file to discover all available pages before exploring further.

# SP Upload Asset

> 上传图片、视频、音频或文本素材到 Seedance SP 经济版素材库。返回 asset_id 可用于 asset:// 引用。

Upload image, video, audio, or text assets to the Seedance SP economy asset library. Use the returned `asset_id` as `asset://{asset_id}` in [SP Create Video](/en/api-reference/seedance/sp/create).

<Note>
  This endpoint is for **SP route** models (economy `seedance2.0-sp` / `seedance2.0-fast-sp` and official `seedance2.0-of-sp` / `seedance2.0-of-fast-sp`). For the full Manxue route, use [Submit Asset Audit](/en/api-reference/seedance/assets-audit).
</Note>

## Request body

| Field  | Type   | Required | Description                                   |
| ------ | ------ | -------- | --------------------------------------------- |
| `name` | string | Yes      | Asset name                                    |
| `type` | string | Yes      | Asset type: `image`, `video`, `audio`, `text` |
| `url`  | string | Yes      | Public asset URL                              |

## Example

```bash theme={null}
curl -X POST 'https://www.jimmyai.cn/api/open-api/v1/seedance/sp/assets/upload' \
  -H 'Authorization: Bearer sk_xxx' \
  -H 'Content-Type: application/json' \
  -d '{
    "name": "reference-1",
    "type": "image",
    "url": "https://example.com/ref.jpg"
  }'
```

## Response

```json theme={null}
{
  "code": 0,
  "msg": "ok",
  "data": {
    "asset_id": "asset_abc123"
  }
}
```

## Next steps

1. Poll [Query Asset Detail](/en/api-reference/seedance/sp/assets-detail) or [Batch Query Asset Status](/en/api-reference/seedance/sp/assets-status)
2. Wait until `status` is `Active`
3. Reference `asset://{asset_id}` in video create requests


## OpenAPI

````yaml POST /api/open-api/v1/seedance/sp/assets/upload
openapi: 3.1.0
info:
  title: Jimmy AI OpenAPI
  description: API for Jimmy AI video generation services
  version: 1.0.0
servers:
  - url: https://www.jimmyai.cn
    description: Production server
security:
  - bearerAuth: []
paths:
  /api/open-api/v1/seedance/sp/assets/upload:
    post:
      summary: SP Upload Asset
      description: >-
        Upload image, video, audio, or text assets to the Seedance SP economy
        library. Returns asset_id for asset:// references.
      operationId: uploadSeedanceSpAsset
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/SeedanceSpAssetUploadRequest'
      responses:
        '200':
          description: Uploaded successfully
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/SeedanceSpAssetUploadResponse'
components:
  schemas:
    SeedanceSpAssetUploadRequest:
      type: object
      required:
        - name
        - type
        - url
      properties:
        name:
          type: string
          description: Asset name
        type:
          type: string
          enum:
            - image
            - video
            - audio
            - text
          description: Asset type
        url:
          type: string
          description: Public asset URL
    SeedanceSpAssetUploadResponse:
      type: object
      properties:
        code:
          type: integer
          example: 0
        msg:
          type: string
          example: ok
        data:
          type: object
          properties:
            asset_id:
              type: string
              description: Asset ID for asset:// references
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer

````