# Import files from web servers

🤖/http/import imports any file that is publicly available via a web URL into Transloadit.

![](/_next/static/media/http-import.0udqawi8axhgx.png?dpl=dpl_BKGqLNQjWctpVS239h7ZAKL6edZN)

The result of this Robot will carry a field `import_url` in their metadata, which references the URL from which they were imported. Further conversion results that use this file will also carry this `import_url` field. This allows you to to match conversion results with the original import URL that you used.

This Robot knows to interpret links to files on these services:

* Dropbox
* Google Drive
* Google Docs
* OneDrive

Instead of downloading the HTML page previewing the file, the actual file itself will be imported.

###### Note

Transloadit supports file sizes up to 200 GB. If you require a higher limit for your application, [get in touch](mailto:hello@transloadit.com?subject=Large%20filesizes).

## Usage example

Import an image from a specific URL:

```
{
  "steps": {
    "imported": {
      "robot": "/http/import",
      "url": "https://demos.transloadit.com/inputs/chameleon.jpg"
    }
  }
}
```

## Parameters

* ### `interpolate`

`boolean | Record<string, boolean>`\
Controls whether Assembly Variables are interpolated for individual instruction fields.\
By default, most Robot instruction fields interpolate Assembly Variables. Set this to `false` to treat every instruction field as literal text, or set an individual field path to `false` to treat only that field as literal text. For Robot-specific fields that are literal by default, set this to `true` or set that field path to `true` to opt back into interpolation.\
Use field names such as `path`, or dotted paths such as `ffmpeg.vf` for nested objects.

* ### `output_meta`

`Record<string, boolean> | boolean | Array<string>`\
Allows you to specify a set of metadata that is more expensive on CPU power to calculate, and thus is disabled by default to keep your Assemblies processing fast.\
For images, you can add `"has_transparency": true` in this object to extract if the image contains transparent parts and `"dominant_colors": true` to extract an array of hexadecimal color codes from the image.\
For images, you can also add `"blurhash": true` to extract a [BlurHash](https://blurha.sh) string — a compact representation of a placeholder for the image, useful for showing a blurred preview while the full image loads.\
For videos, you can add the `"colorspace: true"` parameter to extract the colorspace of the output video.\
For audio, you can add `"mean_volume": true` to get a single value representing the mean average volume of the audio file.\
You can also set this to `false` to skip metadata extraction and speed up transcoding.

* ### `result`

`boolean` (default: `false`)\
Whether the results of this Step should be present in the Assembly Status JSON

* ### `queue`

`batch`\
Setting the queue to 'batch', manually downgrades the priority of jobs for this step to avoid consuming Priority job slots for jobs that don't need zero queue waiting times

* ### `force_accept`

`boolean` (default: `false`)\
Force a Robot to accept a file type it would have ignored.\
By default, Robots ignore files they are not familiar with.[🤖/video/encode](/docs/robots/video-encode.md), for example, will happily ignore input images.\
With the `force_accept` parameter set to `true`, you can force Robots to accept all files thrown at them. This will typically lead to errors and should only be used for debugging or combatting edge cases.

* ### `force_name`

`string | Array<string> | null` (default: `null`)\
Custom name for the imported file(s). By default file names are derived from the source.

* ### `url` — **required**

`string | Array<string>`\
The URL from which the file to be imported can be retrieved.\
You can also specify an array of URLs or a string of `|` delimited URLs to import several files at once. Please also check the `url_delimiter` parameter for that.

* ### `url_delimiter`

`string` (default: `"|"`)\
Provides the delimiter that is used to split the URLs in your `url` parameter value.

* ### `headers`

`Array<string> | Array<Record<string, string>> | string` (default: `[]`)\
Custom headers to be sent for file import.\
This is an empty array by default, such that no additional headers except the necessary ones (e.g. Host) are sent.\
Headers can be specified as:

* An array of strings in the format "Header-Name: value"
* An array of objects with header names as keys and values as values
* A JSON string that will be parsed into an object\
  The same `headers` value is sent with every URL in this `/http/import` Step. If `url` is an array, `headers` is not matched to the URLs by array index. Use separate `/http/import` Steps when different URLs need different headers.
* ### `import_on_errors`

`Array<string>` (default: `[]`)\
Setting this to `"meta"` will still import the file on metadata extraction errors. `ignore_errors` is similar, it also ignores the error and makes sure the Robot doesn't stop, but it doesn't import the file.

* ### `fail_fast`

`boolean` (default: `false`)\
Disable the internal retry mechanism, and fail immediately if a resource can't be imported. This can be useful for performance critical applications.

* ### `return_file_stubs`

`boolean` (default: `false`)\
If set to `true`, the Robot will not yet import the actual files but instead return an empty file stub that includes a URL from where the file can be imported by subsequent Robots. This is useful for cases where subsequent Steps need more control over the import process, such as with 🤖/video/ondemand. This parameter should only be set if all subsequent Steps use Robots that support file stubs.

* ### `range`

`string | Array<string>`\
Allows you to specify one or more byte ranges to import from the file. The server must support range requests for this to work.\
**Single range**: Use a string like `"0-99"` to import bytes 0-99 (the first 100 bytes).\
**Multiple ranges**: Use an array like `["0-99", "200-299"]` to import multiple separate ranges. The resulting file will contain all requested ranges concatenated together, with zero bytes (\0) filling any gaps between non-contiguous ranges.\
**Range formats**:

* `"0-99"`: Bytes 0 through 99 (inclusive)
* `"100-199"`: Bytes 100 through 199 (inclusive)
* `"-100"`: The last 100 bytes of the file\
  **Important notes**:
* The server must support HTTP range requests (respond with 206 Partial Content)
* If the server doesn't support range requests, the entire file will be imported instead
* Overlapping ranges are allowed and will be included as requested
* The resulting file size will be the highest byte position requested, with gaps filled with zero bytes

## Demos

* [Service to change the name of a file imported over HTTP](/demos/file-importing/change-name-of-http-imported-file/)
* [Service to import files over HTTP](/demos/file-importing/import-a-file-over-http/)

## Related blog posts

* [Launching audio encode Robot & exciting new updates](/blog/2011/11/audio-encoding-is-officially-released-now/) November 21, 2011
* [Enhancements: multi-file import & uk rackspace support](/blog/2012/02/uk-based-rackspace-auth-and-multi-url-http-import/) February 11, 2012
* [Addressing elevated queue times & ensuring reliability](/blog/2012/03/last-nights-elevated-queuetimes/) March 31, 2012
* [Launching Assembly Notification for enhanced workflows](/blog/2013/04/announcing-our-new-assembly-notification-system/) April 8, 2013
* [API & jQuery SDK 2.3.0 enhancements announced](/blog/2013/11/api-updates-and-jquery-plugin-version-2-3-0/) November 29, 2013
* [Introducing our new virus scanning Robot for safer uploads](/blog/2015/07/new-robot-for-virus-detection/) July 14, 2015
* [New pricing model for future Transloadit customers](/blog/2018/02/raising-prices/) February 7, 2018
* [Transloadit launches Turbo Mode for faster video encoding](/blog/2018/11/launching-turbo-in-public-beta/) November 15, 2018
* [Easily burn subtitles into videos with our new Robot](/blog/2018/12/intro-to-the-subtitle-bot/) December 6, 2018
* [Tutorial: using /video/merge to develop video slideshows](/blog/2019/06/slideshow-tutorial/) June 14, 2019
* [No-code real-time video uploading with Bubble & Transloadit](/blog/2019/08/lets-build-a-website-with-video-encoding-with-no-code/) August 2, 2019
* [Let's Build: spinning record GIF generator](/blog/2021/04/record-gif/) April 1, 2021
* [Convert Markdown files to HTML or PDF in seconds](/blog/2021/04/md-to-pdf/) April 19, 2021
* [Enhancing /http/import Robot with fail fast option](/blog/2021/06/fast-failing-for-http-import/) June 1, 2021
* [Let's Build: video from album art with Transloadit](/blog/2021/10/video-artwork/) October 10, 2021
* [Celebrating transloadit’s 2021 milestones and progress](/blog/2022/01/21-highlights/) January 31, 2022
* [Build a Reddit video subtitling bot with Transloadit](/blog/2022/02/reddit-video-subtitler/) February 10, 2022
* [Let's Build: music card generator with Transloadit](/blog/2022/05/music-cards/) May 5, 2022
