ElevenLabs Music icon

ElevenLabs Music API

Long-form composition (up to 5 min).

Integrate ElevenLabs Music with a single API call — one key, one unified endpoint, and shared billing across every model on Apiframe.

model: "elevenlabs-music"

What's special about ElevenLabs Music

  • Generates natively synchronized audio.
  • Fast turnaround — about 60s per generation on average.
  • Pay-as-you-go pricing with no ElevenLabs account required — you only pay for successful generations.
  • One API key, unified billing, idempotency and webhooks across every Apiframe model.

Made with ElevenLabs Music

A few outputs generated through the ElevenLabs Music API on Apiframe.

Sample coming soon

Upbeat indie pop track with bright guitars and a catchy chorus

Sample coming soon

Lo-fi hip hop beat with mellow piano and soft vinyl crackle

Sample coming soon

Epic orchestral cinematic score with soaring strings and percussion

Overview

Endpoint
POST /v2/music/generate
Model ID
elevenlabs-music
Params key
elevenlabsParams
Modality
music
Provider
ElevenLabs
Avg. completion
~60s

Capabilities

AudioSupported
Avg. time~60s

Quick start

Send a single POST /v2/music/generate request with your API key to generate with ElevenLabs Music. The call returns a jobId you can poll or receive via webhook.

curl -X POST https://api.apiframe.ai/v2/music/generate \
  -H "X-API-Key: afk_your_api_key_here" \
  -H "Content-Type: application/json" \
  -d '{
        "prompt": "an upbeat synthwave track with a driving bassline",
        "model": "elevenlabs-music",
        "elevenlabsParams": {
            "music_length_ms": 60000,
            "force_instrumental": false,
            "output_format": "mp3_high_quality"
        }
    }'
import requests

response = requests.post(
    "https://api.apiframe.ai/v2/music/generate",
    headers={
        "X-API-Key": "afk_your_api_key_here",
        "Content-Type": "application/json",
    },
    json={
        "prompt": "an upbeat synthwave track with a driving bassline",
        "model": "elevenlabs-music",
        "elevenlabsParams": {
            "music_length_ms": 60000,
            "force_instrumental": False,
            "output_format": "mp3_high_quality"
        }
    },
)
print(response.json())  # { "jobId": "...", "status": "QUEUED" }
const response = await fetch("https://api.apiframe.ai/v2/music/generate", {
  method: "POST",
  headers: {
    "X-API-Key": "afk_your_api_key_here",
    "Content-Type": "application/json",
  },
  body: JSON.stringify({
    "prompt": "an upbeat synthwave track with a driving bassline",
    "model": "elevenlabs-music",
    "elevenlabsParams": {
      "music_length_ms": 60000,
      "force_instrumental": false,
      "output_format": "mp3_high_quality"
    }
  }),
});
const { jobId } = await response.json();
console.log(jobId);

Response & job lifecycle

Generation is asynchronous. A successful submission returns 202 Accepted with a jobId. Poll GET /v2/jobs/{id} (or supply a webhook_url) until the status is COMPLETED; the result field then holds the output URL(s).

1. Submission response (202)

{
  "jobId": "b2c3d4e5-f6a7-8901-bcde-f23456789012",
  "status": "QUEUED"
}

2. Poll for the result

curl https://api.apiframe.ai/v2/jobs/JOB_ID \
  -H "X-API-Key: afk_your_api_key_here"
import requests, time

while True:
    job = requests.get(
        "https://api.apiframe.ai/v2/jobs/JOB_ID",
        headers={"X-API-Key": "afk_your_api_key_here"},
    ).json()
    if job["status"] in ("COMPLETED", "FAILED"):
        break
    time.sleep(2)
print(job["result"])
let job;
do {
  await new Promise((r) => setTimeout(r, 2000));
  job = await fetch("https://api.apiframe.ai/v2/jobs/JOB_ID", {
    headers: { "X-API-Key": "afk_your_api_key_here" },
  }).then((r) => r.json());
} while (job.status !== "COMPLETED" && job.status !== "FAILED");
console.log(job.result);

Input schema

Request parameters accepted by the ElevenLabs Music endpoint. Model-specific options are nested under the params object shown below.

Parameter Type Required Default Allowed / range Description
prompt string required Text description of what to generate.
model string required "elevenlabs-music" "elevenlabs-music" The model identifier for this endpoint.
elevenlabsParams.music_length_ms number optional 60000 min 5000, max 300000, step 1000 5,000 ms = 5 seconds · 300,000 ms = 5 minutes.
elevenlabsParams.force_instrumental boolean optional false Instrumental
elevenlabsParams.output_format string optional "mp3_high_quality" "mp3_standard", "mp3_high_quality", "wav_16khz", "wav_22khz", "wav_24khz", "wav_cd_quality" Output format

Frequently Asked Questions

Common questions about the ElevenLabs Music API.

Is there an API for ElevenLabs Music?

Yes. Apiframe exposes ElevenLabs Music through a single REST endpoint (`POST /v2/music/generate` with `model: "elevenlabs-music"`). You get one unified API, key, and billing across every supported model — no separate ElevenLabs account required.

How much does the ElevenLabs Music API cost?

ElevenLabs Music uses simple pay-as-you-go pricing on Apiframe — you only pay for successful generations. See the pricing page for plans and volume discounts.

How do I call the ElevenLabs Music API?

Send a POST request to `/v2/music/generate` with your `X-API-Key` and a JSON body containing `model: "elevenlabs-music"`. The call returns a `jobId`; poll `GET /v2/jobs/{id}` or use a webhook to receive the result.

What parameters does ElevenLabs Music support?

ElevenLabs Music accepts 3 model-specific parameters (nested under `elevenlabsParams`) plus the common `prompt` and `webhook_url` fields. See the input schema above for the full list with types and defaults.

Still have questions?

Start building with the ElevenLabs Music API

Get your API key and integrate ElevenLabs Music in minutes — Pay-as-you-go.

Free credits to start
One API for every model
Webhooks, SDKs & idempotency
No provider account required

Questions? Join our Discord or contact sales.