This page describes how to perform common operations with the AssemblyAI APIs. Each endpoint is documented individually and grouped by the resource it interacts with.
The Pre-recorded Speech-to-Text API uses REST with JSON-encoded request bodies and responses, and is available at the following URL:
To use our EU server for Pre-recorded STT, replace api.assemblyai.com with
api.eu.assemblyai.com. See Cloud Endpoints and Data
Residency for more information.
To make authorized calls to the REST API, your app must provide an authorization header with an API key. You can find your API key in the AssemblyAI dashboard.
The examples here contain a placeholder, <YOUR_API_KEY>, that you need to replace with your actual API key.
The AssemblyAI API uses HTTP response codes to indicate whether a request was successful.
The response codes generally fall into the following ranges:
2xx indicates the request was successful.4xx indicates the request may have omitted a required parameter, or have invalid information.5xx indicates an error on AssemblyAI’s end.Below is a summary of the HTTP response codes you may encounter:
To stay up-to-date with any known service disruptions, subscribe to updates on the Status page.
Transcriptions may fail due to errors while processing the audio data.
When you query a transcription that has failed, the response will have a 200 code, along with status set to error and an error property with more details.
Common reasons why a transcription may fail include:
In the rare event of a transcription failure due to a server error, you may resubmit the file for transcription. If the problems persist after resubmitting, let us know.
The Streaming Speech-to-Text API uses WebSockets for real-time audio transcription. See Streaming API reference for full endpoint documentation.
To use our EU server for Streaming STT, use streaming.eu.assemblyai.com. See
Streaming Endpoints and Data Zones
for more information.
Streaming STT uses the same API key for authentication as Pre-recorded STT. Pass the API key as a query parameter or in the initial WebSocket message.
The LLM Gateway API provides a unified interface for interacting with multiple LLM providers through a single endpoint.
To use our EU server for LLM Gateway, replace llm-gateway.assemblyai.com
with llm-gateway.eu.assemblyai.com. See Cloud Endpoints and Data
Residency for more
information.
LLM Gateway uses the same API key for authentication as Pre-recorded STT. Pass your API key in the Authorization header.
To ensure the LLM Gateway API remains available for all users, you can only make a limited number of requests within a 60-second time window. These rate limits are specific to each LLM Gateway model.
If you exceed the limit, the API will respond with a 429 status code.
To see your remaining quota, check the following response headers:
If the response doesn’t include X-RateLimit headers, the endpoint doesn’t have rate limits.
If you want to increase the rate limit for your account, contact us.
When AssemblyAI makes backwards-incompatible changes to the API, we release a new version. For information on API updates, see Changelog.
Endpoints are versioned using a path prefix, such as /v2.