Upload the asset to your Runway account

August 8, 2024 (July 22, 2025)

Table of contents

  1. Request Headers
  2. Query Parameters
  3. Request Body
  4. Responses
  5. Model
  6. Examples
  7. Try It

Runway Assets.

IMPORTANT
If you have multiple accounts configured, you must specify the desired account where assets will be uploaded via the email parameter. All API endpoints where an asset is used will use the same account to execute the generation as the one where the asset was uploaded. So, by uploading an asset to the desired account, you effectively select that account for generation with that asset.

POST raw content using Make.com and similar nocode tools.

https://api.useapi.net/v1/runwayml/assets/?…

Request Headers
Authorization: Bearer {API token}
Content-Type: select from the table below
  • API token is required, see Setup useapi.net for details.
  • Content-Type is required, select from the table below:
Content-Type File Extension
image/png png
image/jpeg jpeg
image/gif gif
image/webp webp
image/mpo mpo
video/mp4 mp4
video/quicktime mov
video/3gpp 3gp
video/x-matroska mkv
video/x-flv flv
video/mpeg mpeg
video/MP2T ts
video/x-msvideo avi
video/x-motion-jpeg mjpeg
video/webm webm
video/ogg ogv
audio/wav wav
audio/wave wav
audio/mpeg mp3
audio/flac flac
audio/ogg ogg
audio/webm webm
Query Parameters
  • email is optional when only one account configured. However, if you have multiple accounts configured, this parameter becomes required.

  • name is required. Specify the name of the asset.

  • width is optional. Specify image or video width in pixels.
    This value is currently used by the following API endpoints:
  • height is optional. Specify image or video height in pixels.
    This value is currently used by the following API endpoints:
Request Body

Provide content of the uploaded file as a binary data.

Responses
  • 200 OK

    {
      "assetId": "user:user_id-runwayml:account_email-asset:asset_uuid",
      "id": "<asset uuid>",
      "user": {
        "id": 1234567,
        "username": "<user name>",
        "firstName": "<first name>",
        "lastName": "<last name>",
        "picture": null,
        "teamName": "<team name>",
        "teamPicture": null
      },
      "createdAt": "2024-08-01T01:02:03.456Z",
      "updatedAt": "2024-08-01T01:02:03.456Z",
      "name": "<asset name>",
      "description": "",
      "type": {
        "name": "image",
        "type": "image",
        "isDirectory": false
      },
      "size": 123456789,
      "url": "<asset url>",
      "previewUrls": ["<asset preview url>"],
      "fileCount": 1,
      "private": true,
      "permissions": {
        "read": true,
        "write": true,
        "admin": true
      },
      "annotated": false,
      "isUserUpload": true,
      "sourceApplication": "web",
      "createdBy": {
        "id": 1234567,
        "username": "<user name>",
        "firstName": "<first name>",
        "lastName": "<last name>",
        "picture": null,
        "teamName": "<team name>",
        "teamPicture": null
      },
      "favorite": false
    }
    
  • 400 Bad Request

    {
        "error": "<Error message>",
        "code": 400
    }
    
  • 401 Unauthorized

    {
      "error": "Unauthorized",
      "code": 401
    }
    
Model
{ // TypeScript, all fields are optional
  assetId: string,
  id: string,
  user: {
    id: number,
    username: string,
    firstName: string,
    lastName: string,
    picture: string,
    teamName: string,
    teamPicture: string,
  },
  createdAt: string,
  updatedAt: string,
  name: string,
  description: string,
  type: {
    name: string,
    type: string,
    isDirectory: boolean,
  },
  size: number,
  url: string,
  previewUrls: string[],
  fileCount: number,
  private: boolean,
  permissions: {
    read: boolean,
    write: boolean,
    admin: boolean,
  },
  annotated: boolean,
  isUserUpload: boolean,
  sourceApplication: string,
  createdBy: {
    id: number,
    username: string,
    firstName: string,
    lastName: string,
    picture: string,
    teamName: string,
    teamPicture: string,
  },
  favorite: boolean  
}
Examples
  • curl -X POST "https://api.useapi.net/v1/runwayml/assets/?name=your_file_name" \
      -H "Authorization: Bearer …" \
      -H "Content-Type: image/jpeg" \
      --data-binary /path/to/your/image_or_video_or_audio_file.jpeg
    
  • const token = "API token";
    const name = "asset name"; 
    const apiUrl = `https://api.useapi.net/v1/runwayml/assets/?name=${name}`; 
    let blob;
    /*
        // Example 1: Fetch image from URL
        const imageUrl = "https://upload.wikimedia.org/wikipedia/commons/7/7d/Mona_Lisa_color_restoration.jpg";
        const responseImage = await fetch(imageUrl);
        blob = await responseImage.blob();
    */
    /* 
        // Example 2: Load image from local file (Blob)
        const fsp = require('fs').promises;
        const imageFileName = "./cat.png";
        blob = new Blob([await fsp.readFile(imageFileName)]);
    */
    /*
        // Example 3: Load from input file html element
        // <input id="image-file" type="file"> 
        const imageFile = document.getElementById(`image-file`);
        if (imageFile.files[0])
            blob = imageFile.files[0]);
    */
    const response = await fetch(apiUrl, {
      method: "POST"
      headers: {
        "Authorization": `Bearer ${token}`,
      },
      body: blob
    });
    const result = await response.json();
    console.log("response", {response, result});
    
  • import requests
    
    token = "API token"
    name = "asset name"
    email = "email"
    api_url = f"https://api.useapi.net/v1/runwayml/assets/?name={name}&email={email}"
    
    headers = {
        'Authorization': f'Bearer {token}',
        'Content-Type': 'image/jpeg'
    }
    
    # # Example 1: Fetch image from URL
    # image_url = "https://upload.wikimedia.org/wikipedia/commons/7/7d/Mona_Lisa_color_restoration.jpg"
    # response_image = requests.get(image_url)
    # file_content = response_image.content
    
    # # Example 2: Load image from local file
    # image_file_path = "./image.jpg"
    # with open(image_file_path, 'rb') as image_file:
    #     file_content = image_file.read()
    
    response = requests.post(api_url, headers=headers, data=file_content)
    print(response, response.json())
    
Try It