Tools
Conversão de texto em fala
OpenClaw pode converter respostas de saída em áudio em 14 provedores de fala e entregar mensagens de voz nativas no Feishu, Matrix, Telegram e WhatsApp, anexos de áudio em todos os outros lugares e streams PCM/Ulaw para telefonia e Talk.
TTS é a metade de saída de fala do modo stt-tts do Talk. Sessões Talk
realtime nativas do provedor sintetizam fala dentro do provedor em tempo real
em vez de chamar este caminho de TTS, enquanto sessões transcription não sintetizam uma
resposta de voz do assistente.
Início rápido
Escolha um provedor
OpenAI e ElevenLabs são as opções hospedadas mais confiáveis. Microsoft e CLI local funcionam sem uma chave de API. Veja a matriz de provedores para a lista completa.
Defina a chave de API
Exporte a variável de ambiente do seu provedor (por exemplo OPENAI_API_KEY,
ELEVENLABS_API_KEY). Microsoft e CLI local não precisam de chave.
Habilite na configuração
Defina messages.tts.auto: "always" e messages.tts.provider:
{
messages: {
tts: {
auto: "always",
provider: "elevenlabs",
},
},
}
Teste no chat
/tts status mostra o estado atual. /tts audio Hello from OpenClaw
envia uma resposta de áudio avulsa.
Provedores compatíveis
| Provedor | Autenticação | Observações |
|---|---|---|
| Azure Speech | AZURE_SPEECH_KEY + AZURE_SPEECH_REGION (também AZURE_SPEECH_API_KEY, SPEECH_KEY, SPEECH_REGION) |
Saída nativa de recado de voz em Ogg/Opus e telefonia. |
| DeepInfra | DEEPINFRA_API_KEY |
TTS compatível com OpenAI. O padrão é hexgrad/Kokoro-82M. |
| ElevenLabs | ELEVENLABS_API_KEY ou XI_API_KEY |
Clonagem de voz, multilíngue, determinístico via seed; transmitido para reprodução de voz no Discord. |
| Google Gemini | GEMINI_API_KEY ou GOOGLE_API_KEY |
TTS em lote pela API Gemini; ciente de persona via promptTemplate: "audio-profile-v1". |
| Gradium | GRADIUM_API_KEY |
Saída de recado de voz e telefonia. |
| Inworld | INWORLD_API_KEY |
API de TTS por streaming. Recado de voz nativo em Opus e telefonia PCM. |
| CLI local | nenhum | Executa um comando TTS local configurado. |
| Microsoft | nenhum | TTS neural público do Edge via node-edge-tts. Melhor esforço, sem SLA. |
| MiniMax | MINIMAX_API_KEY (ou Token Plan: MINIMAX_OAUTH_TOKEN, MINIMAX_CODE_PLAN_KEY, MINIMAX_CODING_API_KEY) |
API T2A v2. O padrão é speech-2.8-hd. |
| OpenAI | OPENAI_API_KEY |
Também usado para resumo automático; aceita instructions de persona. |
| OpenRouter | OPENROUTER_API_KEY (pode reutilizar models.providers.openrouter.apiKey) |
Modelo padrão hexgrad/kokoro-82m. |
| Volcengine | VOLCENGINE_TTS_API_KEY ou BYTEPLUS_SEED_SPEECH_API_KEY (AppID/token legado: VOLCENGINE_TTS_APPID/_TOKEN) |
API HTTP BytePlus Seed Speech. |
| Vydra | VYDRA_API_KEY |
Provedor compartilhado de imagem, vídeo e fala. |
| xAI | XAI_API_KEY |
TTS em lote da xAI. Recado de voz nativo em Opus não é compatível. |
| Xiaomi MiMo | XIAOMI_API_KEY |
TTS MiMo por meio de conclusões de chat da Xiaomi. |
Se vários provedores estiverem configurados, o selecionado é usado primeiro e os
outros são opções de fallback. O resumo automático usa summaryModel (ou
agents.defaults.model.primary), então esse provedor também precisa estar autenticado
se você mantiver resumos habilitados.
Configuração
A configuração de TTS fica em messages.tts em ~/.openclaw/openclaw.json. Escolha uma
predefinição e adapte o bloco do provedor:
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,
},
},
},
},
}
CLI local
{
messages: {
tts: {
auto: "always",
provider: "tts-local-cli",
providers: {
"tts-local-cli": {
command: "say",
args: ["-o", "{{OutputPath}}", "{{Text}}"],
outputFormat: "wav",
timeoutMs: 120000,
},
},
},
},
}
Microsoft (sem chave)
{
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",
},
},
},
},
}
Substituições de voz por agente
Use agents.list[].tts quando um agente deve falar com um provedor,
voz, modelo, persona ou modo Auto-TTS diferente. O bloco do agente faz uma mesclagem profunda sobre
messages.tts, então as credenciais do provedor podem permanecer na configuração global do provedor:
{
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" },
},
},
},
],
},
}
Para fixar uma persona por agente, defina agents.list[].tts.persona junto com a configuração do provedor — ela substitui a messages.tts.persona global apenas para esse agente.
Ordem de precedência para respostas automáticas, /tts audio, /tts status e a ferramenta de agente tts:
messages.ttsagents.list[].ttsativo- substituição de canal, quando o canal oferece suporte a
channels.<channel>.tts - substituição de conta, quando o canal passa
channels.<channel>.accounts.<id>.tts - preferências locais de
/ttspara este host - diretivas embutidas
[[tts:...]]quando substituições de modelo estão habilitadas
Substituições de canal e conta usam o mesmo formato de messages.tts e fazem mesclagem profunda sobre as camadas anteriores, para que credenciais compartilhadas de provedor possam permanecer em messages.tts enquanto um canal ou conta de bot altera apenas a voz, o modelo, a persona ou o modo automático:
{
messages: {
tts: {
provider: "openai",
providers: {
openai: { apiKey: "${OPENAI_API_KEY}", model: "gpt-4o-mini-tts" },
},
},
},
channels: {
feishu: {
accounts: {
english: {
tts: {
providers: {
openai: { voice: "shimmer" },
},
},
},
},
},
},
}
Personas
Uma persona é uma identidade falada estável que pode ser aplicada deterministicamente entre provedores. Ela pode preferir um provedor, definir uma intenção de prompt neutra em relação ao provedor e carregar associações específicas de provedor para vozes, modelos, modelos de prompt, sementes e configurações de voz.
Persona mínima
{
messages: {
tts: {
auto: "always",
persona: "narrator",
personas: {
narrator: {
label: "Narrator",
provider: "elevenlabs",
providers: {
elevenlabs: { voiceId: "EXAVITQu4vr4xnSDxMaL", modelId: "eleven_multilingual_v2" },
},
},
},
},
},
}
Persona completa (prompt neutro em relação ao provedor)
{
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,
},
},
},
},
},
},
},
}
Resolução da persona
A persona ativa é selecionada deterministicamente:
- preferência local
/tts persona <id>, se definida. messages.tts.persona, se definida.- Nenhuma persona.
A seleção de provedor executa primeiro as opções explícitas:
- Substituições diretas (CLI, Gateway, Talk, diretivas TTS permitidas).
- preferência local
/tts provider <id>. providerda persona ativa.messages.tts.provider.- seleção automática do registro.
Para cada tentativa de provedor, o OpenClaw mescla configurações nesta ordem:
messages.tts.providers.<id>messages.tts.personas.<persona>.providers.<id>- Substituições confiáveis da solicitação
- Substituições permitidas de diretivas TTS emitidas pelo modelo
Como os provedores usam prompts de persona
Os campos de prompt de persona (profile, scene, sampleContext, style, accent, pacing, constraints) são neutros em relação ao provedor. Cada provedor decide como usá-los:
Google Gemini
Envolve os campos de prompt da persona em uma estrutura de prompt TTS do Gemini somente quando a configuração efetiva do provedor Google define promptTemplate: "audio-profile-v1" ou personaPrompt. Os campos antigos audioProfile e speakerName ainda são prefixados como texto de prompt específico do Google. Tags de áudio embutidas, como [whispers] ou [laughs] dentro de um bloco [[tts:text]], são preservadas dentro da transcrição do Gemini; o OpenClaw não gera essas tags.
OpenAI
Mapeia os campos de prompt da persona para o campo instructions da solicitação somente quando nenhuma instructions explícita do OpenAI está configurada. instructions explícitas sempre prevalecem.
Outros provedores
Use apenas as associações de persona específicas do provedor em personas.<id>.providers.<provider>. Os campos de prompt de persona são ignorados, a menos que o provedor implemente seu próprio mapeamento de prompt de persona.
Política de contingência
fallbackPolicy controla o comportamento quando uma persona não tem associação para o provedor tentado:
| Política | Comportamento |
|---|---|
preserve-persona |
Padrão. Os campos de prompt neutros em relação ao provedor continuam disponíveis; o provedor pode usá-los ou ignorá-los. |
provider-defaults |
A persona é omitida da preparação do prompt para essa tentativa; o provedor usa seus padrões neutros enquanto a contingência para outros provedores continua. |
fail |
Pule essa tentativa de provedor com reasonCode: "not_configured" e personaBinding: "missing". Provedores de contingência ainda são tentados. |
Toda a solicitação TTS só falha quando todos os provedores tentados são ignorados ou falham.
A seleção de provedor da sessão Talk tem escopo de sessão. Um cliente Talk deve escolher
ids de provedor, ids de modelo, ids de voz e localidades a partir de talk.catalog e passá-los
pela sessão Talk ou pela solicitação de transferência. Abrir uma sessão de voz não deve
alterar messages.tts nem os padrões globais de provedor Talk.
Diretivas orientadas por modelo
Por padrão, o assistente pode emitir diretivas [[tts:...]] para substituir
voz, modelo ou velocidade em uma única resposta, além de um bloco opcional
[[tts:text]]...[[/tts:text]] para indicações expressivas que devem aparecer
somente no áudio:
Here you go.
[[tts:voiceId=pMsXgVXv3BLzUgSXRplE model=eleven_v3 speed=1.1]]
[[tts:text]](laughs) Read the song once more.[[/tts:text]]
Quando messages.tts.auto é "tagged", diretivas são obrigatórias para acionar
áudio. A entrega de blocos por streaming remove as diretivas do texto visível antes que o
canal as veja, mesmo quando divididas entre blocos adjacentes.
provider=... é ignorado, a menos que modelOverrides.allowProvider: true. Quando uma
resposta declara provider=..., as outras chaves nessa diretiva são analisadas
somente por esse provedor; chaves sem suporte são removidas e relatadas como avisos
de diretiva TTS.
Chaves de diretiva disponíveis:
provider(id de provedor registrado; requerallowProvider: true)voice/voiceName/voice_name/google_voice/voiceIdmodel/google_modelstability,similarityBoost,style,speed,useSpeakerBoostvol/volume(volume do MiniMax, 0-10)pitch(tom inteiro do MiniMax, -12 a 12; valores fracionários são truncados)emotion(tag de emoção Volcengine)applyTextNormalization(auto|on|off)languageCode(ISO 639-1)seed
Desativar completamente as substituições de modelo:
{ messages: { tts: { modelOverrides: { enabled: false } } } }
Permitir troca de provedor mantendo outros controles configuráveis:
{ messages: { tts: { modelOverrides: { enabled: true, allowProvider: true, allowSeed: false } } } }
Comandos de barra
Comando único /tts. No Discord, o OpenClaw também registra /voice porque
/tts é um comando integrado do Discord — texto /tts ... ainda funciona.
/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>
Notas de comportamento:
/tts ongrava a preferência local de TTS comoalways;/tts offa grava comooff./tts chat on|off|defaultgrava uma substituição de auto-TTS com escopo de sessão para o chat atual./tts persona <id>grava a preferência local de persona;/tts persona offa limpa./tts latestlê a resposta mais recente do assistente na transcrição da sessão atual e a envia como áudio uma vez. Ele armazena somente um hash dessa resposta na entrada da sessão para suprimir envios de voz duplicados./tts audiogera uma resposta de áudio avulsa (não ativa o TTS).limitesummarysão armazenados em preferências locais, não na configuração principal./tts statusinclui diagnósticos de fallback da tentativa mais recente —Fallback: <primary> -> <used>,Attempts: ...e detalhes por tentativa (provider:outcome(reasonCode) latency)./statusmostra o modo TTS ativo, além de provedor, modelo, voz e metadados sanitizados de endpoint personalizado configurados quando o TTS está habilitado.
Preferências por usuário
Comandos de barra gravam substituições locais em prefsPath. O padrão é
~/.openclaw/settings/tts.json; substitua com a variável de ambiente OPENCLAW_TTS_PREFS
ou messages.tts.prefsPath.
| Campo armazenado | Efeito |
|---|---|
auto |
Substituição local de auto-TTS (always, off, ...) |
provider |
Substituição local do provedor primário |
persona |
Substituição local de persona |
maxLength |
Limite para resumo (padrão 1500 caracteres) |
summarize |
Alternância de resumo (padrão true) |
Esses valores substituem a configuração efetiva de messages.tts mais o bloco
agents.list[].tts ativo para esse host.
Formatos de saída (fixos)
A entrega de voz TTS é orientada pelos recursos do canal. Plugins de canal anunciam
se o TTS em estilo de voz deve pedir aos provedores um destino nativo voice-note ou
manter a síntese normal de audio-file e apenas marcar a saída compatível para entrega
de voz.
- Canais compatíveis com mensagens de voz: respostas em mensagem de voz preferem Opus (
opus_48000_64da ElevenLabs,opusda OpenAI).- 48 kHz / 64 kbps é um bom equilíbrio para mensagens de voz.
- Feishu / WhatsApp: quando uma resposta em mensagem de voz é produzida como MP3/WebM/WAV/M4A
ou outro arquivo provavelmente de áudio, o plugin do canal a transcodifica para Ogg/Opus
a 48 kHz com
ffmpegantes de enviar a mensagem de voz nativa. O WhatsApp envia o resultado pelo payloadaudiodo Baileys comptt: trueeaudio/ogg; codecs=opus. Se a conversão falhar, o Feishu recebe o arquivo original como anexo; o envio do WhatsApp falha em vez de publicar um payload PTT incompatível. - BlueBubbles: mantém a síntese do provedor no caminho normal de arquivo de áudio; saídas MP3 e CAF são marcadas para entrega como memo de voz do iMessage.
- Outros canais: MP3 (
mp3_44100_128da ElevenLabs,mp3da OpenAI).- 44,1 kHz / 128 kbps é o equilíbrio padrão para clareza de fala.
- MiniMax: MP3 (modelo
speech-2.8-hd, taxa de amostragem de 32 kHz) para anexos de áudio normais. Para destinos de mensagem de voz anunciados pelo canal, o OpenClaw transcodifica o MP3 da MiniMax para Opus a 48 kHz comffmpegantes da entrega quando o canal anuncia transcodificação. - Xiaomi MiMo: MP3 por padrão, ou WAV quando configurado. Para destinos de mensagem de voz anunciados pelo canal, o OpenClaw transcodifica a saída da Xiaomi para Opus a 48 kHz com
ffmpegantes da entrega quando o canal anuncia transcodificação. - CLI local: usa o
outputFormatconfigurado. Destinos de mensagem de voz são convertidos para Ogg/Opus e a saída de telefonia é convertida para PCM mono bruto de 16 kHz comffmpeg. - Google Gemini: a TTS da API Gemini retorna PCM bruto de 24 kHz. O OpenClaw o encapsula como WAV para anexos de áudio, o transcodifica para Opus a 48 kHz para destinos de mensagem de voz e retorna PCM diretamente para Talk/telefonia.
- Gradium: WAV para anexos de áudio, Opus para destinos de mensagem de voz e
ulaw_8000a 8 kHz para telefonia. - Inworld: MP3 para anexos de áudio normais,
OGG_OPUSnativo para destinos de mensagem de voz ePCMbruto a 22050 Hz para Talk/telefonia. - xAI: MP3 por padrão;
responseFormatpode sermp3,wav,pcm,mulawoualaw. O OpenClaw usa o endpoint TTS REST em lote da xAI e retorna um anexo de áudio completo; o WebSocket de TTS em streaming da xAI não é usado por este caminho de provedor. O formato Opus nativo para mensagens de voz não é compatível com este caminho. - Microsoft: usa
microsoft.outputFormat(padrãoaudio-24khz-48kbitrate-mono-mp3).- O transporte incluído aceita um
outputFormat, mas nem todos os formatos estão disponíveis no serviço. - Os valores de formato de saída seguem os formatos de saída do Microsoft Speech (incluindo Ogg/WebM Opus).
- O
sendVoicedo Telegram aceita OGG/MP3/M4A; use OpenAI/ElevenLabs se precisar de mensagens de voz Opus garantidas. - Se o formato de saída configurado da Microsoft falhar, o OpenClaw tenta novamente com MP3.
- O transporte incluído aceita um
Os formatos de saída da OpenAI/ElevenLabs são fixos por canal (veja acima).
Comportamento de TTS automático
Quando messages.tts.auto está habilitado, o OpenClaw:
- Ignora TTS se a resposta já contém mídia ou uma diretiva
MEDIA:. - Ignora respostas muito curtas (menos de 10 caracteres).
- Resume respostas longas quando resumos estão habilitados, usando
summaryModel(ouagents.defaults.model.primary). - Anexa o áudio gerado à resposta.
- Em
mode: "final", ainda envia TTS somente em áudio para respostas finais transmitidas por streaming após o fluxo de texto ser concluído; a mídia gerada passa pela mesma normalização de mídia do canal que anexos de resposta normais.
Se a resposta exceder maxLength e o resumo estiver desativado (ou não houver chave de API para o
modelo de resumo), o áudio será ignorado e a resposta de texto normal será enviada.
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
Formatos de saída por canal
| Destino | Formato |
|---|---|
| Feishu / Matrix / Telegram / WhatsApp | Respostas em nota de voz preferem Opus (opus_48000_64 da ElevenLabs, opus da OpenAI). 48 kHz / 64 kbps equilibra clareza e tamanho. |
| Outros canais | MP3 (mp3_44100_128 da ElevenLabs, mp3 da OpenAI). Padrão de 44,1 kHz / 128 kbps para fala. |
| Talk / telefonia | PCM nativo do provedor (Inworld 22050 Hz, Google 24 kHz), ou ulaw_8000 da Gradium para telefonia. |
Observações por provedor:
- Transcodificação Feishu / WhatsApp: Quando uma resposta em nota de voz chega como MP3/WebM/WAV/M4A, o Plugin do canal transcodifica para Ogg/Opus a 48 kHz com
ffmpeg. WhatsApp envia por meio do Baileys comptt: trueeaudio/ogg; codecs=opus. Se a conversão falhar: Feishu recorre a anexar o arquivo original; o envio pelo WhatsApp falha em vez de publicar uma carga PTT incompatível. - MiniMax / Xiaomi MiMo: MP3 padrão (32 kHz para MiniMax
speech-2.8-hd); transcodificado para Opus a 48 kHz para destinos de nota de voz viaffmpeg. - CLI local: Usa o
outputFormatconfigurado. Destinos de nota de voz são convertidos para Ogg/Opus e a saída de telefonia para PCM mono bruto de 16 kHz. - Google Gemini: Retorna PCM bruto de 24 kHz. OpenClaw encapsula como WAV para anexos, transcodifica para Opus a 48 kHz para destinos de nota de voz, retorna PCM diretamente para Talk/telefonia.
- Inworld: Anexos MP3, nota de voz nativa
OGG_OPUS,PCMbruto a 22050 Hz para Talk/telefonia. - xAI: MP3 por padrão;
responseFormatpode sermp3|wav|pcm|mulaw|alaw. Usa o endpoint REST em lote da xAI — TTS por WebSocket em streaming não é usado. O formato nativo Opus para nota de voz não é compatível. - Microsoft: Usa
microsoft.outputFormat(padrãoaudio-24khz-48kbitrate-mono-mp3). OsendVoicedo Telegram aceita OGG/MP3/M4A; use OpenAI/ElevenLabs se precisar de mensagens de voz Opus garantidas. Se o formato Microsoft configurado falhar, OpenClaw tenta novamente com MP3.
Os formatos de saída da OpenAI e da ElevenLabs são fixos por canal, conforme listado acima.
Referência de campos
messages.tts.* de nível superior
auto"off" | "always" | "inbound" | "tagged"Modo Auto-TTS. inbound só envia áudio após uma mensagem de voz recebida; tagged só envia áudio quando a resposta inclui diretivas [[tts:...]] ou um bloco [[tts:text]].
enabledbooleanAlternância legada. openclaw doctor --fix migra isto para auto.
mode"final" | "all""all" inclui respostas de ferramenta/bloco além das respostas finais.
providerstringID do provedor de fala. Quando não definido, OpenClaw usa o primeiro provedor configurado na ordem de seleção automática do registro. provider: "edge" legado é reescrito para "microsoft" por openclaw doctor --fix.
personastringID da persona ativa de personas. Normalizado para minúsculas.
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InBlcnNvbmFzLjxpZA
" type="object">
Identidade falada estável. Campos: label, description, provider, fallbackPolicy, prompt, providers.<provider>. Veja Personas.
summaryModelstringModelo barato para resumo automático; o padrão é agents.defaults.model.primary. Aceita provider/model ou um alias de modelo configurado.
modelOverridesobjectPermite que o modelo emita diretivas TTS. enabled tem padrão true; allowProvider tem padrão false.
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InByb3ZpZGVycy48aWQ
" type="object">
Configurações pertencentes ao provedor, indexadas pelo ID do provedor de fala. Blocos diretos legados (messages.tts.openai, .elevenlabs, .microsoft, .edge) são reescritos por openclaw doctor --fix; confirme apenas messages.tts.providers.<id>.
maxTextLengthnumberLimite rígido para caracteres de entrada TTS. /tts audio falha se excedido.
timeoutMsnumberTempo limite da solicitação em milissegundos.
prefsPathstringSubstitui o caminho JSON de preferências locais (provedor/limite/resumo). Padrão ~/.openclaw/settings/tts.json.
Azure Speech
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Env: AZURE_SPEECH_KEY, AZURE_SPEECH_API_KEY ou SPEECH_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlZ2lvbiIgdHlwZT0ic3RyaW5nIg
Região do Azure Speech (por exemplo, eastus). Env: AZURE_SPEECH_REGION ou SPEECH_REGION.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImVuZHBvaW50IiB0eXBlPSJzdHJpbmci
Substituição opcional do endpoint do Azure Speech (alias baseUrl).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
ShortName da voz do Azure. Padrão en-US-JennyNeural.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImxhbmciIHR5cGU9InN0cmluZyI
Código de idioma SSML. Padrão en-US.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im91dHB1dEZvcm1hdCIgdHlwZT0ic3RyaW5nIg
X-Microsoft-OutputFormat do Azure para áudio padrão. Padrão audio-24khz-48kbitrate-mono-mp3.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlTm90ZU91dHB1dEZvcm1hdCIgdHlwZT0ic3RyaW5nIg
X-Microsoft-OutputFormat do Azure para saída de nota de voz. Padrão ogg-24khz-16bit-mono-opus.
OPENCLAW_DOCS_MARKER:paramClose:
ElevenLabs
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Recorre a ELEVENLABS_API_KEY ou XI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
ID do modelo (por exemplo, eleven_multilingual_v2, eleven_v3).
OPENCLAW_DOCS_MARKER:paramClose:
voiceIdstringvoiceSettingsobjectstability, similarityBoost, style (cada um 0..1), useSpeakerBoost (true|false), speed (0.5..2.0, 1.0 = normal).
applyTextNormalization"auto" | "on" | "off"OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Imxhbmd1YWdlQ29kZSIgdHlwZT0ic3RyaW5nIg
ISO 639-1 de 2 letras (por exemplo, en, de).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InNlZWQiIHR5cGU9Im51bWJlciI
Inteiro 0..4294967295 para determinismo de melhor esforço.
OPENCLAW_DOCS_MARKER:paramClose:
baseUrlstringGoogle Gemini
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Recorre a GEMINI_API_KEY / GOOGLE_API_KEY. Se omitido, TTS pode reutilizar models.providers.google.apiKey antes de recorrer ao env.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Modelo TTS Gemini. Padrão gemini-3.1-flash-tts-preview.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlTmFtZSIgdHlwZT0ic3RyaW5nIg
Nome de voz pré-construída do Gemini. Padrão Kore. Alias: voice.
OPENCLAW_DOCS_MARKER:paramClose:
audioProfilestringspeakerNamestringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InByb21wdFRlbXBsYXRlIiB0eXBlPSciYXVkaW8tcHJvZmlsZS12MSIn
Defina como audio-profile-v1 para envolver campos do prompt da persona ativa em uma estrutura determinística de prompt TTS Gemini.
OPENCLAW_DOCS_MARKER:paramClose:
personaPromptstringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Somente https://generativelanguage.googleapis.com é aceito.
OPENCLAW_DOCS_MARKER:paramClose:
Gradium
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Ambiente: GRADIUM_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Padrão https://api.gradium.ai.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Padrão Emma (YTpq7expH9539ERJ).
OPENCLAW_DOCS_MARKER:paramClose:
Inworld
Inworld principal
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Ambiente: INWORLD_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Padrão https://api.inworld.ai.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsSWQiIHR5cGU9InN0cmluZyI
Padrão inworld-tts-1.5-max. Também: inworld-tts-1.5-mini, inworld-tts-1-max, inworld-tts-1.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Padrão Sarah.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InRlbXBlcmF0dXJlIiB0eXBlPSJudW1iZXIi
Temperatura de amostragem 0..2.
OPENCLAW_DOCS_MARKER:paramClose:
CLI local (tts-local-cli)
commandstringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFyZ3MiIHR5cGU9InN0cmluZ1tdIg
Argumentos do comando. Compatível com os placeholders {{Text}}, {{OutputPath}}, {{OutputDir}}, {{OutputBase}}.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im91dHB1dEZvcm1hdCIgdHlwZT0nIm1wMyIgfCAib3B1cyIgfCAid2F2Iic
Formato de saída esperado da CLI. Padrão mp3 para anexos de áudio.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InRpbWVvdXRNcyIgdHlwZT0ibnVtYmVyIg
Tempo limite do comando em milissegundos. Padrão 120000.
OPENCLAW_DOCS_MARKER:paramClose:
cwdstringenv"Record<string,Microsoft (sem chave de API)
enabledbooleanOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Nome da voz neural da Microsoft (por exemplo, en-US-MichelleNeural).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImxhbmciIHR5cGU9InN0cmluZyI
Código de idioma (por exemplo, en-US).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im91dHB1dEZvcm1hdCIgdHlwZT0ic3RyaW5nIg
Formato de saída da Microsoft. Padrão audio-24khz-48kbitrate-mono-mp3. Nem todos os formatos são compatíveis com o transporte incluído baseado no Edge.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJhdGUgLyBwaXRjaCAvIHZvbHVtZSIgdHlwZT0ic3RyaW5nIg
Strings de porcentagem (por exemplo, +10%, -5%).
OPENCLAW_DOCS_MARKER:paramClose:
saveSubtitlesbooleanproxystringtimeoutMsnumberOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImVkZ2UuKiIgdHlwZT0ib2JqZWN0IiBkZXByZWNhdGVk
Alias legado. Execute openclaw doctor --fix para reescrever a configuração persistida para providers.microsoft.
OPENCLAW_DOCS_MARKER:paramClose:
MiniMax
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Recorre a MINIMAX_API_KEY. Autenticação do Token Plan via MINIMAX_OAUTH_TOKEN, MINIMAX_CODE_PLAN_KEY ou MINIMAX_CODING_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Padrão https://api.minimax.io. Ambiente: MINIMAX_API_HOST.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Padrão speech-2.8-hd. Ambiente: MINIMAX_TTS_MODEL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Padrão English_expressive_narrator. Ambiente: MINIMAX_TTS_VOICE_ID.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InNwZWVkIiB0eXBlPSJudW1iZXIi
0.5..2.0. Padrão 1.0.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvbCIgdHlwZT0ibnVtYmVyIg
(0, 10]. Padrão 1.0.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InBpdGNoIiB0eXBlPSJudW1iZXIi
Inteiro -12..12. Padrão 0. Valores fracionários são truncados antes da solicitação.
OPENCLAW_DOCS_MARKER:paramClose:
OpenAI
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Recorre a OPENAI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
ID do modelo de TTS da OpenAI (por exemplo, gpt-4o-mini-tts).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Nome da voz (por exemplo, alloy, cedar).
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Imluc3RydWN0aW9ucyIgdHlwZT0ic3RyaW5nIg
Campo instructions explícito da OpenAI. Quando definido, os campos de prompt de persona não são mapeados automaticamente.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImV4dHJhQm9keSAvIGV4dHJhX2JvZHkiIHR5cGU9IlJlY29yZDxzdHJpbmcsIHVua25vd24
">Campos JSON extras mesclados aos corpos de solicitação de /audio/speech após os campos de TTS gerados da OpenAI. Use isto para endpoints compatíveis com OpenAI, como Kokoro, que exigem chaves específicas do provedor, como lang; chaves de protótipo inseguras são ignoradas.
OPENCLAW_DOCS_MARKER:paramClose:
baseUrlstringSubstitua o endpoint de TTS da OpenAI. Ordem de resolução: configuração → OPENAI_TTS_BASE_URL → https://api.openai.com/v1. Valores não padrão são tratados como endpoints de TTS compatíveis com OpenAI, portanto nomes personalizados de modelo e voz são aceitos.
OpenRouter
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Ambiente: OPENROUTER_API_KEY. Pode reutilizar models.providers.openrouter.apiKey.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Padrão https://openrouter.ai/api/v1. O legado https://openrouter.ai/v1 é normalizado.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Padrão hexgrad/kokoro-82m. Alias: modelId.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Padrão af_alloy. Alias: voiceId.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlc3BvbnNlRm9ybWF0IiB0eXBlPScibXAzIiB8ICJwY20iJw
Padrão mp3.
OPENCLAW_DOCS_MARKER:paramClose:
speednumberVolcengine (BytePlus Seed Speech)
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Ambiente: VOLCENGINE_TTS_API_KEY ou BYTEPLUS_SEED_SPEECH_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlc291cmNlSWQiIHR5cGU9InN0cmluZyI
Padrão seed-tts-1.0. Ambiente: VOLCENGINE_TTS_RESOURCE_ID. Use seed-tts-2.0 quando seu projeto tiver direito ao TTS 2.0.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwcEtleSIgdHlwZT0ic3RyaW5nIg
Cabeçalho da chave do app. Padrão aGjiRDfUWi. Ambiente: VOLCENGINE_TTS_APP_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Substitua o endpoint HTTP de TTS do Seed Speech. Ambiente: VOLCENGINE_TTS_BASE_URL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Tipo de voz. Padrão en_female_anna_mars_bigtts. Ambiente: VOLCENGINE_TTS_VOICE.
OPENCLAW_DOCS_MARKER:paramClose:
speedRationumberemotionstringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwcElkIC8gdG9rZW4gLyBjbHVzdGVyIiB0eXBlPSJzdHJpbmciIGRlcHJlY2F0ZWQ
Campos legados do Volcengine Speech Console. Ambiente: VOLCENGINE_TTS_APPID, VOLCENGINE_TTS_TOKEN, VOLCENGINE_TTS_CLUSTER (padrão volcano_tts).
OPENCLAW_DOCS_MARKER:paramClose:
xAI
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Ambiente: XAI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Padrão https://api.x.ai/v1. Ambiente: XAI_BASE_URL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlSWQiIHR5cGU9InN0cmluZyI
Padrão eve. Vozes ativas: ara, eve, leo, rex, sal, una.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Imxhbmd1YWdlIiB0eXBlPSJzdHJpbmci
Código de idioma BCP-47 ou auto. Padrão en.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InJlc3BvbnNlRm9ybWF0IiB0eXBlPScibXAzIiB8ICJ3YXYiIHwgInBjbSIgfCAibXVsYXciIHwgImFsYXciJw
Padrão mp3.
OPENCLAW_DOCS_MARKER:paramClose:
speednumberXiaomi MiMo
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImFwaUtleSIgdHlwZT0ic3RyaW5nIg
Ambiente: XIAOMI_API_KEY.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImJhc2VVcmwiIHR5cGU9InN0cmluZyI
Padrão https://api.xiaomimimo.com/v1. Ambiente: XIAOMI_BASE_URL.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Im1vZGVsIiB0eXBlPSJzdHJpbmci
Padrão mimo-v2.5-tts. Ambiente: XIAOMI_TTS_MODEL. Também é compatível com mimo-v2-tts.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InZvaWNlIiB0eXBlPSJzdHJpbmci
Padrão mimo_default. Ambiente: XIAOMI_TTS_VOICE.
OPENCLAW_DOCS_MARKER:paramClose:
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9ImZvcm1hdCIgdHlwZT0nIm1wMyIgfCAid2F2Iic
Padrão mp3. Ambiente: XIAOMI_TTS_FORMAT.
OPENCLAW_DOCS_MARKER:paramClose:
stylestringFerramenta do agente
A ferramenta tts converte texto em fala e retorna um anexo de áudio para
entrega da resposta. No Feishu, Matrix, Telegram e WhatsApp, o áudio é
entregue como mensagem de voz em vez de anexo de arquivo. Feishu e
WhatsApp podem transcodificar a saída de TTS que não seja Opus nesse caminho quando ffmpeg está
disponível.
O WhatsApp envia áudio pelo Baileys como uma nota de voz PTT (audio com
ptt: true) e envia o texto visível separadamente do áudio PTT porque
os clientes não renderizam legendas de forma consistente em notas de voz.
A ferramenta aceita os campos opcionais channel e timeoutMs; timeoutMs é um
tempo limite de solicitação do provedor por chamada em milissegundos.
RPC do Gateway
| Método | Finalidade |
|---|---|
tts.status |
Ler o estado atual do TTS e a última tentativa. |
tts.enable |
Definir a preferência automática local como always. |
tts.disable |
Definir a preferência automática local como off. |
tts.convert |
Conversão avulsa de texto → áudio. |
tts.setProvider |
Definir a preferência local de provedor. |
tts.setPersona |
Definir a preferência local de persona. |
tts.providers |
Listar provedores configurados e status. |
Links de serviço
- Guia de texto para fala da OpenAI
- Referência da API de áudio da OpenAI
- Texto para fala REST do Azure Speech
- Provedor Azure Speech
- Texto para fala da ElevenLabs
- Autenticação da ElevenLabs
- Gradium
- API de TTS da Inworld
- API MiniMax T2A v2
- API HTTP de TTS da Volcengine
- Síntese de fala Xiaomi MiMo
- node-edge-tts
- Formatos de saída do Microsoft Speech
- Texto para fala da xAI