Media Library

Importing assets to Media Library

Import assets in bulk and automatically categorize with aspect data.

When importing assets to the library, there are two primary goals:

  • Upload the media so it can be used in a studio or another application.
  • Assign aspect data so that the asset is categorized and tagged correctly.

There are multiple ways to import assets into your library to accomplish these goals together. The recommended way is to use the Command Line Interface. You can run npx sanity media import --help for a quick summary of syntax and options.

Import using the CLI

The media import command operates on a directory or archive that can have three components:

  • An images directory for files that should be uploaded as an image.
  • A files directory for non-image files.
  • A data.ndjson file that contains aspect data for any of the files contained in the images or files directories.
.
├── data.ndjson
├── images
│   └── ...all image files
└── files
    └── ...all other files

The import command uploads every file contained within the images and files directories to the library. If an asset with a matching SHA-1 hash is identified within the library, then that file is skipped.

data.ndjson format

data.ndjson is a newline-delimited JSON file (NDJSON) that can contain aspect information for any of the processed files. Each line must be a valid JSON object containing the information that should be associated with a single file.

Here's an are examples of sample JSON objects used to define a few aspects for files:

However, NDJSON uses the newline character as delimiter to combine multiple JSON objects into a single file. Here's the two example objects combined into a single NDJSON file.

Each JSON object for an asset has two components:

  • filename: The relative path to the file you want to apply the aspect information to.
  • aspects: The aspect data that should be saved attached to the asset.

Once you've prepared your files, you can run the import using the Sanity CLI.

What should I import?

Protip

Import using a client library

If you prefer not to use our CLI import tool, you may run the import yourself by using the HTTP API.

There are some common pitfalls to keep in mind:

  • Concurrency: While you may have thousands of assets to import, you shouldn't trigger thousands of requests in parallel. This is going to exceed API rate limits and might fail. We advise you to use a queue with a reasonably low concurrency.
    Use a library to keep your import below our API rate limit:
  • API usage limits: Importing large libraries can quickly cause a lot of requests, especially if you import a single asset per request. It is usually a good idea to send multiple mutations within a single transaction.
  • Mutation size limits: While it's a good idea to do multiple mutations per transaction, you need to make sure that the size of the request is within our limits, in terms of byte size.

Was this page helpful?