Tools
Tekst-naar-spraak
OpenClaw kan uitgaande antwoorden omzetten naar audio via 14 spraakproviders en native spraakberichten leveren op Feishu, Matrix, Telegram en WhatsApp, audiobijlagen overal elders, en PCM/Ulaw-streams voor telefonie en Talk.
TTS is de helft voor spraakuitvoer van Talks stt-tts-modus. Provider-native
realtime Talk-sessies synthetiseren spraak binnen de realtime-provider in plaats
van dit TTS-pad aan te roepen, terwijl transcription-sessies geen
spraakantwoord van de assistent synthetiseren.
Snel aan de slag
Kies een provider
OpenAI en ElevenLabs zijn de betrouwbaarste gehoste opties. Microsoft en Local CLI werken zonder API-sleutel. Zie de providermatrix voor de volledige lijst.
Stel de API-sleutel in
Exporteer de omgevingsvariabele voor je provider (bijvoorbeeld OPENAI_API_KEY,
ELEVENLABS_API_KEY). Microsoft en Local CLI hebben geen sleutel nodig.
Schakel in de configuratie in
Stel messages.tts.auto: "always" en messages.tts.provider in:
{
messages: {
tts: {
auto: "always",
provider: "elevenlabs",
},
},
}
Probeer het in chat
/tts status toont de huidige status. /tts audio Hello from OpenClaw
stuurt een eenmalig audioantwoord.
Ondersteunde providers
| Provider | Authenticatie | Opmerkingen |
|---|---|---|
| Azure Speech | AZURE_SPEECH_KEY + AZURE_SPEECH_REGION (ook AZURE_SPEECH_API_KEY, SPEECH_KEY, SPEECH_REGION) |
Native Ogg/Opus-uitvoer voor spraaknotities en telefonie. |
| DeepInfra | DEEPINFRA_API_KEY |
OpenAI-compatibele TTS. Standaard hexgrad/Kokoro-82M. |
| ElevenLabs | ELEVENLABS_API_KEY of XI_API_KEY |
Stemklonen, meertalig, deterministisch via seed. |
| Google Gemini | GEMINI_API_KEY of GOOGLE_API_KEY |
Gemini API TTS; persona-bewust via promptTemplate: "audio-profile-v1". |
| Gradium | GRADIUM_API_KEY |
Uitvoer voor spraaknotities en telefonie. |
| Inworld | INWORLD_API_KEY |
Streaming TTS API. Native Opus-spraaknotitie en PCM-telefonie. |
| Local CLI | geen | Voert een geconfigureerde lokale TTS-opdracht uit. |
| Microsoft | geen | Publieke Edge neural TTS via node-edge-tts. Best-effort, geen SLA. |
| MiniMax | MINIMAX_API_KEY (of Token Plan: MINIMAX_OAUTH_TOKEN, MINIMAX_CODE_PLAN_KEY, MINIMAX_CODING_API_KEY) |
T2A v2 API. Standaard speech-2.8-hd. |
| OpenAI | OPENAI_API_KEY |
Ook gebruikt voor automatische samenvatting; ondersteunt persona-instructions. |
| OpenRouter | OPENROUTER_API_KEY (kan models.providers.openrouter.apiKey hergebruiken) |
Standaardmodel hexgrad/kokoro-82m. |
| Volcengine | VOLCENGINE_TTS_API_KEY of BYTEPLUS_SEED_SPEECH_API_KEY (legacy AppID/token: VOLCENGINE_TTS_APPID/_TOKEN) |
BytePlus Seed Speech HTTP API. |
| Vydra | VYDRA_API_KEY |
Gedeelde provider voor afbeeldingen, video en spraak. |
| xAI | XAI_API_KEY |
xAI batch-TTS. Native Opus-spraaknotitie wordt niet ondersteund. |
| Xiaomi MiMo | XIAOMI_API_KEY |
MiMo TTS via Xiaomi chat completions. |
Als meerdere providers zijn geconfigureerd, wordt de geselecteerde eerst gebruikt en zijn de
andere fallbackopties. Automatische samenvatting gebruikt summaryModel (of
agents.defaults.model.primary), dus die provider moet ook geauthenticeerd zijn
als je samenvattingen ingeschakeld houdt.
Configuratie
TTS-configuratie staat onder messages.tts in ~/.openclaw/openclaw.json. Kies een
preset en pas het providerblok aan:
Azure Speech
{
messages: {
tts: {
auto: "always",
provider: "azure-speech",
providers: {
"azure-speech": {
apiKey: "${AZURE_SPEECH_KEY}",
region: "eastus",
voice: "en-US-JennyNeural",
lang: "en-US",
outputFormat: "audio-24khz-48kbitrate-mono-mp3",
voiceNoteOutputFormat: "ogg-24khz-16bit-mono-opus",
},
},
},
},
}
ElevenLabs
{
messages: {
tts: {
auto: "always",
provider: "elevenlabs",
providers: {
elevenlabs: {
apiKey: "${ELEVENLABS_API_KEY}",
model: "eleven_multilingual_v2",
voiceId: "EXAVITQu4vr4xnSDxMaL",
},
},
},
},
}
Google Gemini
{
messages: {
tts: {
auto: "always",
provider: "google",
providers: {
google: {
apiKey: "${GEMINI_API_KEY}",
model: "gemini-3.1-flash-tts-preview",
voiceName: "Kore",
// Optional natural-language style prompts:
// audioProfile: "Speak in a calm, podcast-host tone.",
// speakerName: "Alex",
},
},
},
},
}
Gradium
{
messages: {
tts: {
auto: "always",
provider: "gradium",
providers: {
gradium: {
apiKey: "${GRADIUM_API_KEY}",
voiceId: "YTpq7expH9539ERJ",
},
},
},
},
}
Inworld
{
messages: {
tts: {
auto: "always",
provider: "inworld",
providers: {
inworld: {
apiKey: "${INWORLD_API_KEY}",
modelId: "inworld-tts-1.5-max",
voiceId: "Sarah",
temperature: 0.7,
},
},
},
},
}
Local CLI
{
messages: {
tts: {
auto: "always",
provider: "tts-local-cli",
providers: {
"tts-local-cli": {
command: "say",
args: ["-o", "{{OutputPath}}", "{{Text}}"],
outputFormat: "wav",
timeoutMs: 120000,
},
},
},
},
}
Microsoft (geen sleutel)
{
messages: {
tts: {
auto: "always",
provider: "microsoft",
providers: {
microsoft: {
enabled: true,
voice: "en-US-MichelleNeural",
lang: "en-US",
outputFormat: "audio-24khz-48kbitrate-mono-mp3",
rate: "+0%",
pitch: "+0%",
},
},
},
},
}
MiniMax
{
messages: {
tts: {
auto: "always",
provider: "minimax",
providers: {
minimax: {
apiKey: "${MINIMAX_API_KEY}",
model: "speech-2.8-hd",
voiceId: "English_expressive_narrator",
speed: 1.0,
vol: 1.0,
pitch: 0,
},
},
},
},
}
OpenAI + ElevenLabs
{
messages: {
tts: {
auto: "always",
provider: "openai",
summaryModel: "openai/gpt-4.1-mini",
modelOverrides: { enabled: true },
providers: {
openai: {
apiKey: "${OPENAI_API_KEY}",
model: "gpt-4o-mini-tts",
voice: "alloy",
},
elevenlabs: {
apiKey: "${ELEVENLABS_API_KEY}",
model: "eleven_multilingual_v2",
voiceId: "EXAVITQu4vr4xnSDxMaL",
voiceSettings: { stability: 0.5, similarityBoost: 0.75, style: 0.0, useSpeakerBoost: true, speed: 1.0 },
applyTextNormalization: "auto",
languageCode: "en",
},
},
},
},
}
OpenRouter
{
messages: {
tts: {
auto: "always",
provider: "openrouter",
providers: {
openrouter: {
apiKey: "${OPENROUTER_API_KEY}",
model: "hexgrad/kokoro-82m",
voice: "af_alloy",
responseFormat: "mp3",
},
},
},
},
}
Volcengine
{
messages: {
tts: {
auto: "always",
provider: "volcengine",
providers: {
volcengine: {
apiKey: "${VOLCENGINE_TTS_API_KEY}",
resourceId: "seed-tts-1.0",
voice: "en_female_anna_mars_bigtts",
},
},
},
},
}
xAI
{
messages: {
tts: {
auto: "always",
provider: "xai",
providers: {
xai: {
apiKey: "${XAI_API_KEY}",
voiceId: "eve",
language: "en",
responseFormat: "mp3",
},
},
},
},
}
Xiaomi MiMo
{
messages: {
tts: {
auto: "always",
provider: "xiaomi",
providers: {
xiaomi: {
apiKey: "${XIAOMI_API_KEY}",
model: "mimo-v2.5-tts",
voice: "mimo_default",
format: "mp3",
},
},
},
},
}
Stemoverschrijvingen per agent
Gebruik agents.list[].tts wanneer één agent met een andere provider,
stem, model, persona of Auto-TTS-modus moet spreken. Het agentblok wordt deep-merged over
messages.tts, zodat providerreferenties in de globale providerconfiguratie kunnen blijven:
{
messages: {
tts: {
auto: "always",
provider: "elevenlabs",
providers: {
elevenlabs: { apiKey: "${ELEVENLABS_API_KEY}", model: "eleven_multilingual_v2" },
},
},
},
agents: {
list: [
{
id: "reader",
tts: {
providers: {
elevenlabs: { voiceId: "EXAVITQu4vr4xnSDxMaL" },
},
},
},
],
},
}
Om een persona per agent vast te zetten, stel je agents.list[].tts.persona in naast de provider-
configuratie — dit overschrijft de globale messages.tts.persona alleen voor die agent.
Rangorde voor automatische antwoorden, /tts audio, /tts status en de
agenttool tts:
messages.tts- actieve
agents.list[].tts - kanaaloverride, wanneer het kanaal
channels.<channel>.ttsondersteunt - accountoverride, wanneer het kanaal
channels.<channel>.accounts.<id>.ttsdoorgeeft - lokale
/tts-voorkeuren voor deze host - inline
[[tts:...]]-richtlijnen wanneer modeloverschrijvingen zijn ingeschakeld
Kanaal- en accountoverrides gebruiken dezelfde vorm als messages.tts en
worden diep samengevoegd over de eerdere lagen, zodat gedeelde providerreferenties in
messages.tts kunnen blijven terwijl een kanaal of botaccount alleen stem, model, persona
of automatische modus wijzigt:
{
messages: {
tts: {
provider: "openai",
providers: {
openai: { apiKey: "${OPENAI_API_KEY}", model: "gpt-4o-mini-tts" },
},
},
},
channels: {
feishu: {
accounts: {
english: {
tts: {
providers: {
openai: { voice: "shimmer" },
},
},
},
},
},
},
}
Persona's
Een persona is een stabiele gesproken identiteit die deterministisch over providers kan worden toegepast. Die kan de voorkeur geven aan één provider, providerneutrale promptintentie definiëren en providerspecifieke bindingen bevatten voor stemmen, modellen, promptsjablonen, seeds en steminstellingen.
Minimale persona
{
messages: {
tts: {
auto: "always",
persona: "narrator",
personas: {
narrator: {
label: "Narrator",
provider: "elevenlabs",
providers: {
elevenlabs: { voiceId: "EXAVITQu4vr4xnSDxMaL", modelId: "eleven_multilingual_v2" },
},
},
},
},
},
}
Volledige persona (providerneutrale prompt)
{
messages: {
tts: {
auto: "always",
persona: "alfred",
personas: {
alfred: {
label: "Alfred",
description: "Dry, warm British butler narrator.",
provider: "google",
fallbackPolicy: "preserve-persona",
prompt: {
profile: "A brilliant British butler. Dry, witty, warm, charming, emotionally expressive, never generic.",
scene: "A quiet late-night study. Close-mic narration for a trusted operator.",
sampleContext: "The speaker is answering a private technical request with concise confidence and dry warmth.",
style: "Refined, understated, lightly amused.",
accent: "British English.",
pacing: "Measured, with short dramatic pauses.",
constraints: ["Do not read configuration values aloud.", "Do not explain the persona."],
},
providers: {
google: {
model: "gemini-3.1-flash-tts-preview",
voiceName: "Algieba",
promptTemplate: "audio-profile-v1",
},
openai: { model: "gpt-4o-mini-tts", voice: "cedar" },
elevenlabs: {
voiceId: "voice_id",
modelId: "eleven_multilingual_v2",
seed: 42,
voiceSettings: {
stability: 0.65,
similarityBoost: 0.8,
style: 0.25,
useSpeakerBoost: true,
speed: 0.95,
},
},
},
},
},
},
},
}
Personaresolutie
De actieve persona wordt deterministisch geselecteerd:
- lokale voorkeur
/tts persona <id>, indien ingesteld. messages.tts.persona, indien ingesteld.- Geen persona.
Providerselectie werkt met expliciet eerst:
- Directe overrides (CLI, Gateway, Talk, toegestane TTS-richtlijnen).
- Lokale voorkeur
/tts provider <id>. - De
providervan de actieve persona. messages.tts.provider.- Automatische registerselectie.
Voor elke providerpoging voegt OpenClaw configuraties in deze volgorde samen:
messages.tts.providers.<id>messages.tts.personas.<persona>.providers.<id>- Vertrouwde requestoverrides
- Toegestane door het model uitgezonden TTS-richtlijnoverrides
Hoe providers personaprompts gebruiken
Personapromptvelden (profile, scene, sampleContext, style, accent,
pacing, constraints) zijn providerneutraal. Elke provider bepaalt hoe
die ze gebruikt:
Google Gemini
Verpakt personapromptvelden in een Gemini TTS-promptstructuur alleen wanneer
de effectieve Google-providerconfiguratie promptTemplate: "audio-profile-v1"
of personaPrompt instelt. De oudere velden audioProfile en speakerName
worden nog steeds vooraf ingevoegd als Google-specifieke prompttekst. Inline audiotags zoals
[whispers] of [laughs] binnen een [[tts:text]]-blok blijven behouden
binnen het Gemini-transcript; OpenClaw genereert deze tags niet.
OpenAI
Koppelt personapromptvelden aan het requestveld instructions alleen wanneer
er geen expliciete OpenAI-instructions is geconfigureerd. Expliciete instructions
winnen altijd.
Andere providers
Gebruiken alleen de providerspecifieke personabindingen onder
personas.<id>.providers.<provider>. Personapromptvelden worden genegeerd,
tenzij de provider een eigen personapromptkoppeling implementeert.
Fallbackbeleid
fallbackPolicy bepaalt het gedrag wanneer een persona geen binding heeft voor de
geprobeerde provider:
| Beleid | Gedrag |
|---|---|
preserve-persona |
Standaard. Providerneutrale promptvelden blijven beschikbaar; de provider kan ze gebruiken of negeren. |
provider-defaults |
Persona wordt weggelaten uit promptvoorbereiding voor die poging; de provider gebruikt zijn neutrale standaardwaarden terwijl fallback naar andere providers doorgaat. |
fail |
Sla die providerpoging over met reasonCode: "not_configured" en personaBinding: "missing". Fallbackproviders worden nog steeds geprobeerd. |
Het volledige TTS-request mislukt alleen wanneer elke geprobeerde provider wordt overgeslagen of mislukt.
Providersselectie voor Talk-sessies is sessiegebonden. Een Talk-client moet
provider-id's, model-id's, stem-id's en locales uit talk.catalog kiezen en
ze doorgeven via de Talk-sessie of het overdrachtsrequest. Het openen van een stemsessie mag
messages.tts of globale standaardwaarden voor Talk-providers niet wijzigen.
Modelgestuurde richtlijnen
Standaard kan de assistant [[tts:...]]-richtlijnen uitzenden om
stem, model of snelheid voor één antwoord te overschrijven, plus een optioneel
[[tts:text]]...[[/tts:text]]-blok voor expressieve aanwijzingen die alleen in
audio moeten verschijnen:
Here you go.
[[tts:voiceId=pMsXgVXv3BLzUgSXRplE model=eleven_v3 speed=1.1]]
[[tts:text]](laughs) Read the song once more.[[/tts:text]]
Wanneer messages.tts.auto "tagged" is, zijn richtlijnen vereist om
audio te activeren. Streamingbloklevering verwijdert richtlijnen uit zichtbare tekst voordat het
kanaal ze ziet, zelfs wanneer ze over aangrenzende blokken zijn gesplitst.
provider=... wordt genegeerd tenzij modelOverrides.allowProvider: true. Wanneer een
antwoord provider=... declareert, worden de andere sleutels in die richtlijn
alleen door die provider geparseerd; niet-ondersteunde sleutels worden verwijderd en gerapporteerd als TTS-
richtlijnwaarschuwingen.
Beschikbare richtlijnsleutels:
provider(geregistreerde provider-id; vereistallowProvider: true)voice/voiceName/voice_name/google_voice/voiceIdmodel/google_modelstability,similarityBoost,style,speed,useSpeakerBoostvol/volume(MiniMax-volume, 0-10)pitch(MiniMax-gehele toonhoogte, −12 tot 12; fractionele waarden worden afgekapt)emotion(Volcengine-emotietag)applyTextNormalization(auto|on|off)languageCode(ISO 639-1)seed
Modeloverschrijvingen volledig uitschakelen:
{ messages: { tts: { modelOverrides: { enabled: false } } } }
Providerwisseling toestaan terwijl andere instellingen configureerbaar blijven:
{ messages: { tts: { modelOverrides: { enabled: true, allowProvider: true, allowSeed: false } } } }
Slash-commando's
Eén commando /tts. Op Discord registreert OpenClaw ook /voice omdat
/tts een ingebouwd Discord-commando is — tekst /tts ... werkt nog steeds.
/tts off | on | status
/tts chat on | off | default
/tts latest
/tts provider <id>
/tts persona <id> | off
/tts limit <chars>
/tts summary off
/tts audio <text>
Gedragsnotities:
/tts onschrijft de lokale TTS-voorkeur naaralways;/tts offschrijft die naaroff./tts chat on|off|defaultschrijft een sessiegebonden auto-TTS-override voor de huidige chat./tts persona <id>schrijft de lokale personavoorkeur;/tts persona offwist die./tts latestleest het nieuwste assistant-antwoord uit het transcript van de huidige sessie en verzendt het eenmaal als audio. Het slaat alleen een hash van dat antwoord op in het sessie-item om dubbele stemverzendingen te onderdrukken./tts audiogenereert een eenmalig audioantwoord (schakelt TTS niet in).limitensummaryworden opgeslagen in lokale voorkeuren, niet in de hoofdconfiguratie./tts statusbevat fallbackdiagnostiek voor de nieuwste poging —Fallback: <primary> -> <used>,Attempts: ...en details per poging (provider:outcome(reasonCode) latency)./statustoont de actieve TTS-modus plus geconfigureerde provider, model, stem en gesaneerde metadata van aangepaste endpoints wanneer TTS is ingeschakeld.
Voorkeuren per gebruiker
Slash-commando's schrijven lokale overrides naar prefsPath. De standaardwaarde is
~/.openclaw/settings/tts.json; overschrijf dit met de env-var OPENCLAW_TTS_PREFS
of messages.tts.prefsPath.
| Opgeslagen veld | Effect |
|---|---|
auto |
Lokale auto-TTS-override (always, off, …) |
provider |
Lokale primaire-provideroverride |
persona |
Lokale personaoverride |
maxLength |
Samenvattingsdrempel (standaard 1500 tekens) |
summarize |
Samenvattingsschakelaar (standaard true) |
Deze overschrijven de effectieve configuratie uit messages.tts plus het actieve
agents.list[].tts-blok voor die host.
Uitvoerformaten (vast)
TTS-stemlevering wordt gestuurd door kanaalmogelijkheden. Kanaal-Plugins adverteren
of TTS in stemstijl providers om een native voice-note-doel moet vragen of
normale audio-file-synthese moet behouden en compatibele uitvoer alleen moet markeren voor stemlevering.
- Kanalen met ondersteuning voor spraaknotities: spraaknotitie-antwoorden geven de voorkeur aan Opus (
opus_48000_64van ElevenLabs,opusvan OpenAI).- 48 kHz / 64 kbps is een goede afweging voor spraakberichten.
- Feishu / WhatsApp: wanneer een spraaknotitie-antwoord wordt geproduceerd als MP3/WebM/WAV/M4A
of een ander waarschijnlijk audiobestand, transcodeert de kanaal-Plugin het naar 48 kHz
Ogg/Opus met
ffmpegvoordat het native spraakbericht wordt verzonden. WhatsApp verzendt het resultaat via de Baileys-audio-payload metptt: trueenaudio/ogg; codecs=opus. Als conversie mislukt, ontvangt Feishu het oorspronkelijke bestand als bijlage; verzending via WhatsApp mislukt in plaats van een incompatibele PTT-payload te plaatsen. - BlueBubbles: houdt providersynthese op het normale pad voor audiobestanden; MP3- en CAF-uitvoer wordt gemarkeerd voor levering als iMessage-spraakmemo.
- Andere kanalen: MP3 (
mp3_44100_128van ElevenLabs,mp3van OpenAI).- 44,1 kHz / 128 kbps is de standaardbalans voor heldere spraak.
- MiniMax: MP3 (
speech-2.8-hd-model, samplefrequentie van 32 kHz) voor normale audiobijlagen. Voor door kanalen geadverteerde doelen voor spraaknotities transcodeert OpenClaw de MiniMax-MP3 vóór levering naar 48 kHz Opus metffmpegwanneer het kanaal transcoding adverteert. - Xiaomi MiMo: standaard MP3, of WAV wanneer geconfigureerd. Voor door kanalen geadverteerde doelen voor spraaknotities transcodeert OpenClaw Xiaomi-uitvoer vóór levering naar 48 kHz Opus met
ffmpegwanneer het kanaal transcoding adverteert. - Lokale CLI: gebruikt de geconfigureerde
outputFormat. Doelen voor spraaknotities worden geconverteerd naar Ogg/Opus en telefonie-uitvoer wordt geconverteerd naar ruwe 16 kHz mono PCM metffmpeg. - Google Gemini: Gemini API TTS retourneert ruwe 24 kHz PCM. OpenClaw verpakt dit als WAV voor audiobijlagen, transcodeert het naar 48 kHz Opus voor doelen voor spraaknotities en retourneert PCM rechtstreeks voor Talk/telefonie.
- Gradium: WAV voor audiobijlagen, Opus voor doelen voor spraaknotities en
ulaw_8000op 8 kHz voor telefonie. - Inworld: MP3 voor normale audiobijlagen, native
OGG_OPUSvoor doelen voor spraaknotities en ruwePCMop 22050 Hz voor Talk/telefonie. - xAI: standaard MP3;
responseFormatkanmp3,wav,pcm,mulawofalawzijn. OpenClaw gebruikt het batch-REST-TTS-eindpunt van xAI en retourneert een volledige audiobijlage; de streaming TTS-WebSocket van xAI wordt niet gebruikt door dit providerpad. Native Opus-formaat voor spraaknotities wordt niet ondersteund door dit pad. - Microsoft: gebruikt
microsoft.outputFormat(standaardaudio-24khz-48kbitrate-mono-mp3).- Het meegeleverde transport accepteert een
outputFormat, maar niet alle formaten zijn beschikbaar vanuit de service. - Waarden voor uitvoerformaten volgen Microsoft Speech-uitvoerformaten (inclusief Ogg/WebM Opus).
- Telegram
sendVoiceaccepteert OGG/MP3/M4A; gebruik OpenAI/ElevenLabs als je gegarandeerde Opus-spraakberichten nodig hebt. - Als het geconfigureerde Microsoft-uitvoerformaat mislukt, probeert OpenClaw het opnieuw met MP3.
- Het meegeleverde transport accepteert een
OpenAI/ElevenLabs-uitvoerformaten zijn per kanaal vastgelegd (zie hierboven).
Auto-TTS-gedrag
Wanneer messages.tts.auto is ingeschakeld, doet OpenClaw het volgende:
- Slaat TTS over als het antwoord al media of een
MEDIA:-instructie bevat. - Slaat zeer korte antwoorden over (minder dan 10 tekens).
- Vat lange antwoorden samen wanneer samenvattingen zijn ingeschakeld, met
summaryModel(ofagents.defaults.model.primary). - Voegt de gegenereerde audio toe aan het antwoord.
- In
mode: "final"wordt nog steeds audio-only TTS verzonden voor gestreamde definitieve antwoorden nadat de tekststream is voltooid; de gegenereerde media doorloopt dezelfde kanaalmedianormalisatie als normale antwoordbijlagen.
Als het antwoord langer is dan maxLength en samenvatten is uitgeschakeld (of er geen API-sleutel is voor het
samenvattingsmodel), wordt audio overgeslagen en wordt het normale tekstantwoord verzonden.
Reply -> TTS enabled?
no -> send text
yes -> has media / MEDIA: / short?
yes -> send text
no -> length > limit?
no -> TTS -> attach audio
yes -> summary enabled?
no -> send text
yes -> summarize -> TTS -> attach audio
Uitvoerformaten per kanaal
| Doel | Formaat |
|---|---|
| Feishu / Matrix / Telegram / WhatsApp | Voice-note-antwoorden geven de voorkeur aan Opus (opus_48000_64 van ElevenLabs, opus van OpenAI). 48 kHz / 64 kbps brengt helderheid en grootte in balans. |
| Andere kanalen | MP3 (mp3_44100_128 van ElevenLabs, mp3 van OpenAI). 44,1 kHz / 128 kbps is de standaard voor spraak. |
| Talk / telefonie | Provider-native PCM (Inworld 22050 Hz, Google 24 kHz), of ulaw_8000 van Gradium voor telefonie. |
Opmerkingen per provider:
- Feishu / WhatsApp-transcodering: Wanneer een voice-note-antwoord binnenkomt als MP3/WebM/WAV/M4A, transcodeert de kanaal-Plugin naar 48 kHz Ogg/Opus met
ffmpeg. WhatsApp verzendt via Baileys metptt: trueenaudio/ogg; codecs=opus. Als conversie mislukt: Feishu valt terug op het bijvoegen van het oorspronkelijke bestand; verzenden via WhatsApp mislukt in plaats van een incompatibele PTT-payload te posten. - MiniMax / Xiaomi MiMo: Standaard MP3 (32 kHz voor MiniMax
speech-2.8-hd); getranscodeerd naar 48 kHz Opus voor voice-note-doelen viaffmpeg. - Lokale CLI: Gebruikt geconfigureerde
outputFormat. Voice-note-doelen worden geconverteerd naar Ogg/Opus en telefonie-uitvoer naar ruwe 16 kHz mono PCM. - Google Gemini: Retourneert ruwe 24 kHz PCM. OpenClaw verpakt dit als WAV voor bijlagen, transcodeert naar 48 kHz Opus voor voice-note-doelen, retourneert PCM direct voor Talk/telefonie.
- Inworld: MP3-bijlagen, native
OGG_OPUSvoice-note, ruwePCM22050 Hz voor Talk/telefonie. - xAI: Standaard MP3;
responseFormatkanmp3|wav|pcm|mulaw|alawzijn. Gebruikt xAI's batch-REST-eindpunt — streaming WebSocket-TTS wordt niet gebruikt. Native Opus-voice-note-formaat wordt niet ondersteund. - Microsoft: Gebruikt
microsoft.outputFormat(standaardaudio-24khz-48kbitrate-mono-mp3). TelegramsendVoiceaccepteert OGG/MP3/M4A; gebruik OpenAI/ElevenLabs als je gegarandeerde Opus-spraakberichten nodig hebt. Als het geconfigureerde Microsoft-formaat mislukt, probeert OpenClaw het opnieuw met MP3.
OpenAI- en ElevenLabs-uitvoerformaten zijn per kanaal vastgezet zoals hierboven vermeld.
Veldreferentie
Top-level messages.tts.*
auto"off" | "always" | "inbound" | "tagged"Auto-TTS-modus. inbound verzendt alleen audio na een inkomend spraakbericht; tagged verzendt alleen audio wanneer het antwoord [[tts:...]]-directieven of een [[tts:text]]-blok bevat.
enabledbooleanVerouderde schakelaar. openclaw doctor --fix migreert dit naar auto.
mode"final" | "all""all" bevat tool-/blokantwoorden naast eindantwoorden.
providerstringSpraakprovider-id. Wanneer niet ingesteld, gebruikt OpenClaw de eerste geconfigureerde provider in de automatische selecteervolgorde van het register. Verouderde provider: "edge" wordt door openclaw doctor --fix herschreven naar "microsoft".
personastringActieve persona-id uit personas. Genormaliseerd naar kleine letters.
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InBlcnNvbmFzLjxpZA
" type="object">
Stabiele gesproken identiteit. Velden: label, description, provider, fallbackPolicy, prompt, providers.<provider>. Zie Persona's.
summaryModelstringGoedkoop model voor automatische samenvatting; standaard agents.defaults.model.primary. Accepteert provider/model of een geconfigureerde modelalias.
modelOverridesobjectSta het model toe TTS-directieven uit te geven. enabled is standaard true; allowProvider is standaard false.
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InByb3ZpZGVycy48aWQ
" type="object">
Provider-owned instellingen, gesleuteld op spraakprovider-id. Verouderde directe blokken (messages.tts.openai, .elevenlabs, .microsoft, .edge) worden herschreven door openclaw doctor --fix; commit alleen messages.tts.providers.<id>.
maxTextLengthnumberHarde limiet voor TTS-invoertekens. /tts audio mislukt als deze wordt overschreden.
timeoutMsnumberAanvraagtime-out in milliseconden.
prefsPathstringOverschrijf het lokale JSON-pad voor voorkeuren (provider/limiet/samenvatting). Standaard ~/.openclaw/settings/tts.json.
Azure Speech
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Env: AZURE_SPEECH_KEY, AZURE_SPEECH_API_KEY, of SPEECH_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlZ2lvbiIgdHlwZT0ic3RyaW5nIg
Azure Speech-regio (bijv. eastus). Env: AZURE_SPEECH_REGION of SPEECH_REGION.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImVuZHBvaW50IiB0eXBlPSJzdHJpbmci
Optionele Azure Speech-eindpuntoverschrijving (alias baseUrl).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Azure-stem ShortName. Standaard en-US-JennyNeural.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImxhbmciIHR5cGU9InN0cmluZyI
SSML-taalcode. Standaard en-US.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im91dHB1dEZvcm1hdCIgdHlwZT0ic3RyaW5nIg
Azure X-Microsoft-OutputFormat voor standaardaudio. Standaard audio-24khz-48kbitrate-mono-mp3.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlTm90ZU91dHB1dEZvcm1hdCIgdHlwZT0ic3RyaW5nIg
Azure X-Microsoft-OutputFormat voor voice-note-uitvoer. Standaard ogg-24khz-16bit-mono-opus.
OPENCLAW_DOCS_MARKER:paramClose:
ElevenLabs
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Valt terug op ELEVENLABS_API_KEY of XI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Model-id (bijv. eleven_multilingual_v2, eleven_v3).
OPENCLAW_DOCS_MARKER:paramClose:
voiceIdstringvoiceSettingsobjectstability, similarityBoost, style (elk 0..1), useSpeakerBoost (true|false), speed (0.5..2.0, 1.0 = normaal).
applyTextNormalization"auto" | "on" | "off"OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Imxhbmd1YWdlQ29kZSIgdHlwZT0ic3RyaW5nIg
2-letterige ISO 639-1 (bijv. en, de).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InNlZWQiIHR5cGU9Im51bWJlciI
Geheel getal 0..4294967295 voor best-effort determinisme.
OPENCLAW_DOCS_MARKER:paramClose:
baseUrlstringGoogle Gemini
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Valt terug op GEMINI_API_KEY / GOOGLE_API_KEY. Indien weggelaten kan TTS models.providers.google.apiKey hergebruiken vóór env-terugval.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Gemini TTS-model. Standaard gemini-3.1-flash-tts-preview.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlTmFtZSIgdHlwZT0ic3RyaW5nIg
Naam van vooraf gebouwde Gemini-stem. Standaard Kore. Alias: voice.
OPENCLAW_DOCS_MARKER:paramClose:
audioProfilestringspeakerNamestringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InByb21wdFRlbXBsYXRlIiB0eXBlPSciYXVkaW8tcHJvZmlsZS12MSIn
Stel in op audio-profile-v1 om actieve persona-promptvelden in een deterministische Gemini TTS-promptstructuur te wikkelen.
OPENCLAW_DOCS_MARKER:paramClose:
personaPromptstringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Alleen https://generativelanguage.googleapis.com wordt geaccepteerd.
OPENCLAW_DOCS_MARKER:paramClose:
Gradium
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Omgeving: GRADIUM_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Standaard https://api.gradium.ai.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Standaard Emma (YTpq7expH9539ERJ).
OPENCLAW_DOCS_MARKER:paramClose:
Inworld
Inworld primair
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Omgeving: INWORLD_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Standaard https://api.inworld.ai.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsSWQiIHR5cGU9InN0cmluZyI
Standaard inworld-tts-1.5-max. Ook: inworld-tts-1.5-mini, inworld-tts-1-max, inworld-tts-1.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Standaard Sarah.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InRlbXBlcmF0dXJlIiB0eXBlPSJudW1iZXIi
Samplingtemperatuur 0..2.
OPENCLAW_DOCS_MARKER:paramClose:
Lokale CLI (tts-local-cli)
commandstringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFyZ3MiIHR5cGU9InN0cmluZ1tdIg
Opdrachtargumenten. Ondersteunt de placeholders {{Text}}, {{OutputPath}}, {{OutputDir}}, {{OutputBase}}.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im91dHB1dEZvcm1hdCIgdHlwZT0nIm1wMyIgfCAib3B1cyIgfCAid2F2Iic
Verwacht CLI-uitvoerformaat. Standaard mp3 voor audiobijlagen.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InRpbWVvdXRNcyIgdHlwZT0ibnVtYmVyIg
Opdrachttime-out in milliseconden. Standaard 120000.
OPENCLAW_DOCS_MARKER:paramClose:
cwdstringenv"Record<string,Microsoft (geen API-sleutel)
enabledbooleanOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Naam van Microsoft neurale stem (bijv. en-US-MichelleNeural).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImxhbmciIHR5cGU9InN0cmluZyI
Taalcode (bijv. en-US).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im91dHB1dEZvcm1hdCIgdHlwZT0ic3RyaW5nIg
Microsoft-uitvoerformaat. Standaard audio-24khz-48kbitrate-mono-mp3. Niet alle formaten worden ondersteund door het meegeleverde Edge-ondersteunde transport.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJhdGUgLyBwaXRjaCAvIHZvbHVtZSIgdHlwZT0ic3RyaW5nIg
Percentagetekenreeksen (bijv. +10%, -5%).
OPENCLAW_DOCS_MARKER:paramClose:
saveSubtitlesbooleanproxystringtimeoutMsnumberOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImVkZ2UuKiIgdHlwZT0ib2JqZWN0IiBkZXByZWNhdGVk
Verouderde alias. Voer openclaw doctor --fix uit om opgeslagen configuratie te herschrijven naar providers.microsoft.
OPENCLAW_DOCS_MARKER:paramClose:
MiniMax
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Valt terug op MINIMAX_API_KEY. Token Plan-authenticatie via MINIMAX_OAUTH_TOKEN, MINIMAX_CODE_PLAN_KEY of MINIMAX_CODING_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Standaard https://api.minimax.io. Omgeving: MINIMAX_API_HOST.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Standaard speech-2.8-hd. Omgeving: MINIMAX_TTS_MODEL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Standaard English_expressive_narrator. Omgeving: MINIMAX_TTS_VOICE_ID.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InNwZWVkIiB0eXBlPSJudW1iZXIi
0.5..2.0. Standaard 1.0.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvbCIgdHlwZT0ibnVtYmVyIg
(0, 10]. Standaard 1.0.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InBpdGNoIiB0eXBlPSJudW1iZXIi
Geheel getal -12..12. Standaard 0. Fractionele waarden worden vóór het verzoek afgekapt.
OPENCLAW_DOCS_MARKER:paramClose:
OpenAI
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Valt terug op OPENAI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
OpenAI TTS-model-id (bijv. gpt-4o-mini-tts).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Stemnaam (bijv. alloy, cedar).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Imluc3RydWN0aW9ucyIgdHlwZT0ic3RyaW5nIg
Expliciet OpenAI-veld instructions. Wanneer ingesteld, worden persona-promptvelden niet automatisch toegewezen.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImV4dHJhQm9keSAvIGV4dHJhX2JvZHkiIHR5cGU9IlJlY29yZDxzdHJpbmcsIHVua25vd24
">Extra JSON-velden die worden samengevoegd in aanvraagbody's voor /audio/speech na gegenereerde OpenAI TTS-velden. Gebruik dit voor OpenAI-compatibele eindpunten zoals Kokoro die providerspecifieke sleutels vereisen, zoals lang; onveilige prototypesleutels worden genegeerd.
OPENCLAW_DOCS_MARKER:paramClose:
baseUrlstringOverschrijf het OpenAI TTS-eindpunt. Resolutievolgorde: configuratie → OPENAI_TTS_BASE_URL → https://api.openai.com/v1. Niet-standaardwaarden worden behandeld als OpenAI-compatibele TTS-eindpunten, zodat aangepaste model- en stemnamen worden geaccepteerd.
OpenRouter
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Omgeving: OPENROUTER_API_KEY. Kan models.providers.openrouter.apiKey hergebruiken.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Standaard https://openrouter.ai/api/v1. Verouderde https://openrouter.ai/v1 wordt genormaliseerd.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Standaard hexgrad/kokoro-82m. Alias: modelId.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Standaard af_alloy. Alias: voiceId.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlc3BvbnNlRm9ybWF0IiB0eXBlPScibXAzIiB8ICJwY20iJw
Standaard mp3.
OPENCLAW_DOCS_MARKER:paramClose:
speednumberVolcengine (BytePlus Seed Speech)
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Omgeving: VOLCENGINE_TTS_API_KEY of BYTEPLUS_SEED_SPEECH_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlc291cmNlSWQiIHR5cGU9InN0cmluZyI
Standaard seed-tts-1.0. Omgeving: VOLCENGINE_TTS_RESOURCE_ID. Gebruik seed-tts-2.0 wanneer je project recht heeft op TTS 2.0.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwcEtleSIgdHlwZT0ic3RyaW5nIg
App-sleutelheader. Standaard aGjiRDfUWi. Omgeving: VOLCENGINE_TTS_APP_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Overschrijf het Seed Speech TTS HTTP-eindpunt. Omgeving: VOLCENGINE_TTS_BASE_URL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Stemtype. Standaard en_female_anna_mars_bigtts. Omgeving: VOLCENGINE_TTS_VOICE.
OPENCLAW_DOCS_MARKER:paramClose:
speedRationumberemotionstringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwcElkIC8gdG9rZW4gLyBjbHVzdGVyIiB0eXBlPSJzdHJpbmciIGRlcHJlY2F0ZWQ
Verouderde Volcengine Speech Console-velden. Omgeving: VOLCENGINE_TTS_APPID, VOLCENGINE_TTS_TOKEN, VOLCENGINE_TTS_CLUSTER (standaard volcano_tts).
OPENCLAW_DOCS_MARKER:paramClose:
xAI
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Omgeving: XAI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Standaard https://api.x.ai/v1. Omgeving: XAI_BASE_URL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Standaard eve. Live stemmen: ara, eve, leo, rex, sal, una.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Imxhbmd1YWdlIiB0eXBlPSJzdHJpbmci
BCP-47-taalcode of auto. Standaard en.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlc3BvbnNlRm9ybWF0IiB0eXBlPScibXAzIiB8ICJ3YXYiIHwgInBjbSIgfCAibXVsYXciIHwgImFsYXciJw
Standaard mp3.
OPENCLAW_DOCS_MARKER:paramClose:
speednumberXiaomi MiMo
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Omgeving: XIAOMI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Standaard https://api.xiaomimimo.com/v1. Omgeving: XIAOMI_BASE_URL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Standaard mimo-v2.5-tts. Omgeving: XIAOMI_TTS_MODEL. Ondersteunt ook mimo-v2-tts.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Standaard mimo_default. Omgeving: XIAOMI_TTS_VOICE.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImZvcm1hdCIgdHlwZT0nIm1wMyIgfCAid2F2Iic
Standaard mp3. Omgeving: XIAOMI_TTS_FORMAT.
OPENCLAW_DOCS_MARKER:paramClose:
stylestringAgenttool
De tool tts zet tekst om naar spraak en retourneert een audiobijlage voor
antwoordlevering. Op Feishu, Matrix, Telegram en WhatsApp wordt de audio
geleverd als spraakbericht in plaats van als bestandsbijlage. Feishu en
WhatsApp kunnen niet-Opus TTS-uitvoer op dit pad transcoderen wanneer ffmpeg
beschikbaar is.
WhatsApp verzendt audio via Baileys als een PTT-spraaknotitie (audio met
ptt: true) en verzendt zichtbare tekst apart van PTT-audio, omdat
clients bijschriften op spraaknotities niet consistent weergeven.
De tool accepteert optionele velden channel en timeoutMs; timeoutMs is een
providerspecifieke aanvraagtime-out per aanroep in milliseconden.
Gateway RPC
| Methode | Doel |
|---|---|
tts.status |
Huidige TTS-status en laatste poging lezen. |
tts.enable |
Lokale automatische voorkeur instellen op always. |
tts.disable |
Lokale automatische voorkeur instellen op off. |
tts.convert |
Eenmalige tekst → audio. |
tts.setProvider |
Lokale providervoorkeur instellen. |
tts.setPersona |
Lokale personavoorkeur instellen. |
tts.providers |
Geconfigureerde providers en status vermelden. |
Servicelinks
- OpenAI-handleiding voor tekst-naar-spraak
- OpenAI Audio API-referentie
- Azure Speech REST tekst-naar-spraak
- Azure Speech-provider
- ElevenLabs tekst-naar-spraak
- ElevenLabs-authenticatie
- Gradium
- Inworld TTS API
- MiniMax T2A v2 API
- Volcengine TTS HTTP API
- Xiaomi MiMo-spraaksynthese
- node-edge-tts
- Microsoft Speech-uitvoerformaten
- xAI tekst-naar-spraak