Audio
Synthèse vocale, parole-texte, musique, effets sonores, modification de la voix, doublage et clonage vocal : une clé API, chaque fournisseur.
Une seule surface audio couvre le text-to-speech, la transcription, la musique, les effets sonores, le dubbing, le voice changing et le voice cloning. Les endpoints principaux sont compatibles OpenAI, tandis que les extras plus riches — voice settings, speaker diarization, dubbing — sont acceptés partout où le provider upstream les prend en charge.
Listez d'abord les voix disponibles ; les voix clonées que vous créez apparaissent dans la même liste et s'utilisent de la même façon.
Endpoints in this section: /v1/audio/speech, /music, /sound-effects, /transcriptions, /audio-isolation, /voice-changer, /dubbing, /voices, plus /v1/voices/* for cloning.
Synthèse vocale
Synthétiser le discours à partir du texte. Renvoie les octets audio bruts avec le type de contenu correspondant (par exemple audio/mpeg). Les formats PCM et µ-law incluent un en-tête WAV afin qu'ils soient lisibles dans n'importe quel navigateur.
https://api.airforce/v1/audio/speechModèles TTS
…· live| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | TTS model ID. See /v1/models for IDs with input_modalities containing "text" and output_modalities containing "audio". |
| input | string | Required | Text to synthesise. Long inputs are chunked automatically. |
| voice | string | Required | Voice ID. Use GET /v1/audio/voices to list options. Cloned voices appear here too. |
| response_format | string | Optional | "mp3" (default), "mp3_44100_128", "mp3_44100_192", "pcm_22050", "pcm_24000", "pcm_44100", "ulaw_8000". |
| speed | float | Optional | 0.25 – 4.0. OpenAI-compatible. Some upstream providers ignore this. |
| voice_settings | object | Optional | ElevenLabs-shape: { stability: 0–1, similarity_boost: 0–1, style: 0–1, use_speaker_boost: bool }. |
| language_code | string | Optional | ISO-639-1 hint, e.g. "de", "en", "ja". Improves prosody for multilingual models. |
| seed | integer | Optional | Reproducibility seed where supported. |
Exemple
curl https://api.airforce/v1/audio/speech \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-H "Content-Type: application/json" \
--output speech.mp3 \
-d '{
"model": "elevenlabs-multilingual-v2",
"input": "Willkommen bei Airforce.",
"voice": "21m00Tcm4TlvDq8ikWAM",
"response_format": "mp3_44100_128",
"voice_settings": {"stability": 0.6, "similarity_boost": 0.8}
}'Liste des voix
Renvoie chaque voix que vous pouvez transmettre en tant que paramètre « voix » lors des appels TTS/voix off/livre audio. Les voix clonées sont également renvoyées ici une fois que leur statut est actif.
https://api.airforce/v1/audio/voicescurl https://api.airforce/v1/audio/voices \
-H "Authorization: Bearer sk-air-YOUR_API_KEY"Forme de la réponse
| Parameter | Type | Required | Description |
|---|---|---|---|
| voices[] | array | Optional | List of voice descriptors. |
| voices[].voice_id | string | Optional | Provider-native voice identifier — the field is voice_id (not id). Pass this value as "voice". |
| voices[].name | string | Optional | Human-readable name. |
| voices[].description | string | Optional | Short description, when the upstream exposes one. |
| voices[].category | string | Optional | "premade" | "cloned" | "professional". |
| voices[].preview_url | string | Optional | Short audio sample, when the upstream exposes one. |
| voices[].labels | object | Optional | Free-form metadata: gender, language, accent, age, use case. |
| live | boolean | Optional | true when the catalog came from a live upstream call; false when served from the built-in premade fallback. |
{
"voices": [
{
"voice_id": "CwhRBWXzGAHq8TQ4Fs17",
"name": "Roger - Laid-Back, Casual, Resonant",
"description": "Easy going and perfect for casual conversations.",
"preview_url": "https://.../58ee3ff5.mp3",
"category": "premade",
"labels": {"accent": "american", "gender": "male", "language": "en", "use_case": "conversational"}
}
],
"live": true
}Génération de musique
Générez des morceaux de musique complets à partir d'une invite de texte. Renvoie l'audio binaire.
https://api.airforce/v1/audio/musicCet endpoint dessert les modèles de musique natifs (p. ex. music-v1). Les modèles Suno (suno-*) ne sont pas disponibles ici et renvoient provider_not_supported — appelez-les plutôt via l'endpoint /v1/images/generations (voir la référence Media).
| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | Music model ID, e.g. "music-v1". |
| prompt | string | Required | Style / mood / structure description. |
| duration_seconds | integer | Optional | Track length. Range depends on the model (typically 15–120 s). |
| response_format | string | Optional | "mp3" (default) or provider-native. |
| instrumental | boolean | Optional | When true, suppresses vocals. |
| style | string | Optional | Optional genre tag list, e.g. "EDM, bass, dark". |
curl https://api.airforce/v1/audio/music \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-H "Content-Type: application/json" \
--output track.mp3 \
-d '{
"model": "music-v1",
"prompt": "Lofi hip-hop beat with soft piano and rain",
"duration_seconds": 60,
"instrumental": true
}'Bruitage
Court SFX à partir d’une invite de texte. Même forme que la musique, mais durées plus courtes.
https://api.airforce/v1/audio/sound-effects| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | SFX model ID. |
| prompt | string | Required | Effect description, e.g. "thunder rumble fading into rain". |
| duration_seconds | integer | Optional | Length, typically 0.5–22 s. |
| response_format | string | Optional | "mp3" (default). |
curl https://api.airforce/v1/audio/sound-effects \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-H "Content-Type: application/json" \
--output thunder.mp3 \
-d '{
"model": "sfx-v1",
"prompt": "Distant thunder rolling, then rain",
"duration_seconds": 8
}'Transcriptions (parole-texte)
Téléchargement en plusieurs parties d'un fichier audio. Renvoie le texte transcrit.
https://api.airforce/v1/audio/transcriptionsModèles de transcription
…· live| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | Transcription model ID. See the live list below for valid IDs. |
| file | binary | Required | Audio file. Supports mp3, wav, m4a, flac, ogg, webm. |
| language_code | string | Optional | ISO-639-1 language hint (also accepted as "language"). Auto-detected when omitted. |
| diarize | boolean | Optional | Separate speakers. When true, each word carries a speaker_id. |
| num_speakers | integer | Optional | Expected speaker count, used together with diarize. |
| tag_audio_events | boolean | Optional | Mark non-speech events (laughter, silence, music) in the output. |
| timestamps_granularity | string | Optional | "word" (default) or "character". |
| additional_formats | string | Optional | Request extra rendered outputs (e.g. srt / vtt) alongside the JSON. |
curl https://api.airforce/v1/audio/transcriptions \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-F "[email protected]" \
-F "model=elevenlabs-scribe" \
-F "language_code=de" \
-F "diarize=true"Forme de la réponse
{
"language_code": "deu",
"language_probability": 0.98,
"text": "Willkommen zum Meeting...",
"words": [
{"text": "Willkommen", "start": 0.0, "end": 0.62, "type": "word", "logprob": -0.08, "speaker_id": "speaker_0"},
{"text": " ", "start": 0.62, "end": 0.62, "type": "spacing", "logprob": 0.0}
],
"audio_duration_secs": 412.5,
"transcription_id": "tx_01HXY..."
}La réponse suit la structure native du fournisseur en amont (ElevenLabs Scribe), et non celle d'OpenAI Whisper : les tokens sont renvoyés sous forme d'un tableau plat words[] (chacun avec un type word/spacing et un logprob), et non segments[]. La durée est audio_duration_secs, et language_code suit la norme ISO-639-3 (p. ex. eng, deu). Le speaker_id par mot n'est présent que si vous passez diarize=true.
Isolation audio
Supprimez le bruit de fond d’un clip tout en préservant la voix du premier plan. Téléchargement en plusieurs parties, renvoie l'audio.
https://api.airforce/v1/audio/audio-isolation| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | Isolation model ID. |
| file | binary | Required | Input audio. |
curl https://api.airforce/v1/audio/audio-isolation \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-F "model=isolation-v1" \
-F "[email protected]" \
--output clean.mp3Changeur de voix (parole à parole)
Prenez la parole saisie et restituez-la avec une voix différente tout en préservant le timing et l'inflexion.
https://api.airforce/v1/audio/voice-changer| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | Voice-change model ID. |
| voice | string | Required | Target voice ID. Same catalog as TTS. |
| file | binary | Required | Input audio. |
| voice_settings | object | Optional | Optional ElevenLabs-shape settings (stability, similarity_boost, …). |
curl https://api.airforce/v1/audio/voice-changer \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-F "model=voice-changer-v1" \
-F "voice=21m00Tcm4TlvDq8ikWAM" \
-F "[email protected]" \
--output transformed.mp3Doublage
Doublage asynchrone vers une langue cible. Renvoie immédiatement un dubbing_id ; interrogez le statut jusqu’à ce qu’il indique "dubbed", puis téléchargez l’audio doublé pour cette langue.
1. Create job
https://api.airforce/v1/audio/dubbing| Parameter | Type | Required | Description |
|---|---|---|---|
| model | string | Required | Dubbing model ID. |
| file | binary | Required | Source audio or video (mp3, wav, m4a, mp4 — audio is extracted automatically). Alternatively pass source_url. |
| target_lang | string | Required | Target language code (ISO-639-1). One language per job — repeating the field does not add languages. |
| source_lang | string | Optional | Source language. "auto" or omit for auto-detect. |
| num_speakers | integer | Optional | Hint for diarization. Auto when omitted. |
| drop_background_audio | boolean | Optional | Remove background music / noise from the dub. |
| watermark | boolean | Optional | Add an audible watermark to the output. |
curl https://api.airforce/v1/audio/dubbing \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-F "model=dubbing-v1" \
-F "[email protected]" \
-F "target_lang=de" \
-F "source_lang=en"{
"dubbing_id": "abc123def456",
"expected_duration_sec": 42.5
}2. Poll status
https://api.airforce/v1/audio/dubbing/:dubbing_idLe statut est transmis tel quel par le fournisseur. status vaut "dubbing" pendant l'exécution et "dubbed" une fois prêt (et non "completed"). Les langues figurent sous target_languages (et non available_languages), et il n'y a pas de champ progress.
{
"dubbing_id": "abc123def456",
"status": "dubbed",
"source_language": "en",
"target_languages": ["de"],
"media_metadata": {"duration": 42.5, "content_type": "video/mp4"},
"name": "english.mp4",
"created_at": "2026-05-06T22:30:00Z",
"editable": false,
"error": null
}3. Download per language
https://api.airforce/v1/audio/dubbing/:dubbing_id/audio/:langcurl https://api.airforce/v1/audio/dubbing/abc123def456/audio/de \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
--output german.mp3Clonage vocal
Clonez une voix à partir de courts échantillons audio et réutilisez-la sur chaque point final de parole. Le clonage vocal nécessite un consentement explicite : récupérez le texte de consentement actuel, hachez-le et soumettez le hachage avec vos échantillons.
1. Fetch consent text
https://api.airforce/v1/voices/consent-text{
"text": "I confirm that the voice samples I am uploading are either my own voice or a voice I have explicit permission to clone…",
"hash": "9f4b0c8d2e…"
}2. Create the clone
https://api.airforce/v1/voices/clone| Parameter | Type | Required | Description |
|---|---|---|---|
| name | string | Required | Public voice name shown in the library. |
| description | string | Optional | Optional free-text description. |
| consent_hash | string | Required | SHA-256 of the consent paragraph. Fetch the current text via GET /v1/voices/consent-text and pass its hash field. |
| files | binary | Required | 1–25 audio samples. Repeat the form field per file. Total ≤ 200 MB. 30 s – 3 min per clip works best. |
curl https://api.airforce/v1/voices/clone \
-H "Authorization: Bearer sk-air-YOUR_API_KEY" \
-F "name=My voice" \
-F "description=Calm, conversational" \
-F "consent_hash=9f4b0c8d2e..." \
-F "[email protected]" \
-F "[email protected]"{
"voice_id": "voice_01HXY...",
"name": "My voice",
"status": "active",
"created_at": "2026-05-06T22:30:00Z"
}Attention aux noms de champs : la réponse de création renvoie la nouvelle voix sous voice_id, tandis que GET /v1/voices/library liste les clones sous provider_voice_id. Les deux contiennent le même identifiant — la valeur que vous passez comme voice.
3. List your library
https://api.airforce/v1/voices/librarycurl https://api.airforce/v1/voices/library \
-H "Authorization: Bearer sk-air-YOUR_API_KEY"| Parameter | Type | Required | Description |
|---|---|---|---|
| voices[].provider_voice_id | string | Optional | Pass as "voice" on TTS / voice-changer endpoints. |
| voices[].status | string | Optional | "active" | "errored" | "deleting". |
| voices[].provider | string | Optional | Upstream that hosts the clone. |
| voices[].last_error | string | Optional | Set when status is "errored". |
4. Update / delete
https://api.airforce/v1/voices/clone/:idhttps://api.airforce/v1/voices/clone/:idPATCH accepts name and description in a JSON body. DELETE removes the voice both locally and at the upstream provider.
Remarques
- Les réponses audio sont renvoyées sous forme d'octets bruts avec le bon
Content-Type. Les formats PCM / µ-law sont encapsulés dans un header WAV minimal afin d'être lisibles tels quels dans le navigateur. - Les endpoints multipart (transcriptions, isolation, voice-changer, doublage, clonage) acceptent jusqu'à 200 Mo par requête.
- Les identifiants de voix fonctionnent entre fournisseurs : une voix ElevenLabs clonée peut être passée directement à
/v1/audio/voice-changer. - Le coût est facturé par caractère (TTS), par seconde (musique / SFX / doublage / voice-changer) ou par minute d'audio (transcription) et est déduit de votre solde. Les endpoints audio n'envoient pas de header de réponse
X-Cost-Cents— suivez vos dépenses dans le journal d'utilisation de votre tableau de bord.