Tools
Geração de música
A ferramenta music_generate permite que o agente crie música ou áudio por meio do
recurso compartilhado de geração de música com provedores configurados: Google,
MiniMax e ComfyUI configurado por workflow atualmente.
Para execuções de agente com sessão, o OpenClaw inicia a geração de música como uma tarefa em segundo plano, acompanha-a no ledger de tarefas e então desperta o agente novamente quando a faixa está pronta para que o agente possa avisar o usuário e anexar o áudio finalizado. Em chats de grupo/canal que usam entrega visível somente por ferramenta de mensagem, o agente retransmite o resultado pela ferramenta de mensagem. Se o agente de conclusão escrever apenas uma resposta final privada, o OpenClaw recorre a um envio direto pelo canal com a mídia gerada. O despertar de conclusão avisa explicitamente o agente de que respostas finais normais são privadas nessas rotas.
Início rápido
Com provedor compartilhado
Configurar autenticação
Defina uma chave de API para pelo menos um provedor — por exemplo
GEMINI_API_KEY ou MINIMAX_API_KEY.
Escolher um modelo padrão (opcional)
{ agents: { defaults: { musicGenerationModel: { primary: "google/lyria-3-clip-preview", }, }, },}Pedir ao agente
"Gere uma faixa synthpop animada sobre dirigir à noite por uma cidade de neon."
O agente chama music_generate automaticamente. Não é necessário
permitir a ferramenta em uma lista.
Para contextos síncronos diretos sem uma execução de agente com sessão, a ferramenta integrada ainda recorre à geração inline e retorna o caminho final da mídia no resultado da ferramenta.
Workflow do ComfyUI
Configurar o workflow
Configure plugins.entries.comfy.config.music com um workflow
JSON e nós de prompt/saída.
Autenticação em nuvem (opcional)
Para o Comfy Cloud, defina COMFY_API_KEY ou COMFY_CLOUD_API_KEY.
Chamar a ferramenta
/tool music_generate prompt="Warm ambient synth loop with soft tape texture"Exemplos de prompts:
Generate a cinematic piano track with soft strings and no vocals.Generate an energetic chiptune loop about launching a rocket at sunrise.Provedores compatíveis
| Provedor | Modelo padrão | Entradas de referência | Controles compatíveis | Autenticação |
|---|---|---|---|---|
| ComfyUI | workflow |
Até 1 imagem | Música ou áudio definidos pelo workflow | COMFY_API_KEY, COMFY_CLOUD_API_KEY |
lyria-3-clip-preview |
Até 10 imagens | lyrics, instrumental, format |
GEMINI_API_KEY, GOOGLE_API_KEY |
|
| MiniMax | music-2.6 |
Nenhuma | lyrics, instrumental, durationSeconds, format=mp3 |
MINIMAX_API_KEY ou OAuth da MiniMax |
Matriz de recursos
O contrato de modo explícito usado por music_generate, testes de contrato e a
varredura live compartilhada:
| Provedor | generate |
edit |
Limite de edição | Lanes live compartilhadas |
|---|---|---|---|---|
| ComfyUI | ✓ | ✓ | 1 imagem | Não incluído na varredura compartilhada; coberto por extensions/comfy/comfy.live.test.ts |
| ✓ | ✓ | 10 imagens | generate, edit |
|
| MiniMax | ✓ | — | Nenhum | generate |
Use action: "list" para inspecionar provedores e modelos compartilhados disponíveis em
runtime:
/tool music_generate action=listUse action: "status" para inspecionar a tarefa ativa de música com sessão:
/tool music_generate action=statusExemplo de geração direta:
/tool music_generate prompt="Dreamy lo-fi hip hop with vinyl texture and gentle rain" instrumental=trueParâmetros da ferramenta
promptstringrequiredPrompt de geração de música. Obrigatório para action: "generate".
action"generate" | "status" | "list"default: generate"status" retorna a tarefa atual da sessão; "list" inspeciona provedores.
modelstringSobrescrita de provedor/modelo (por exemplo, google/lyria-3-pro-preview,
comfy/workflow).
lyricsstringLetra opcional quando o provedor oferece suporte a entrada explícita de letra.
instrumentalbooleanSolicita saída apenas instrumental quando o provedor oferece suporte.
imagestringCaminho ou URL de uma única imagem de referência.
imagesstring[]Várias imagens de referência (até 10 em provedores compatíveis).
durationSecondsnumberDuração alvo em segundos quando o provedor oferece suporte a dicas de duração.
format"mp3" | "wav"Dica de formato de saída quando o provedor oferece suporte.
filenamestringOPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9InRpbWVvdXRNcyIgdHlwZT0ibnVtYmVyIg
Timeout opcional da solicitação ao provedor em milissegundos. Quando omitido, o OpenClaw usa agents.defaults.musicGenerationModel.timeoutMs se configurado. Valores abaixo de 10000ms são elevados para 10000ms e informados no resultado da ferramenta.
OPENCLAW_DOCS_MARKER:paramClose:
Comportamento assíncrono
A geração de música com sessão é executada como uma tarefa em segundo plano:
- Tarefa em segundo plano:
music_generatecria uma tarefa em segundo plano, retorna uma resposta de iniciada/tarefa imediatamente e publica a faixa finalizada posteriormente em uma mensagem de acompanhamento do agente. - Prevenção de duplicatas: enquanto uma tarefa está
queuedourunning, chamadasmusic_generateposteriores na mesma sessão retornam o status da tarefa em vez de iniciar outra geração. Useaction: "status"para verificar explicitamente. - Consulta de status:
openclaw tasks listouopenclaw tasks show <taskId>inspeciona status em fila, em execução e terminal. - Despertar de conclusão: o OpenClaw injeta um evento interno de conclusão de volta na mesma sessão para que o modelo possa escrever o acompanhamento voltado ao usuário por conta própria.
- Dica de prompt: turnos posteriores de usuário/manuais na mesma sessão recebem uma pequena
dica de runtime quando uma tarefa de música já está em andamento, para que o modelo
não chame
music_generatenovamente às cegas. - Fallback sem sessão: contextos diretos/locais sem uma sessão real de agente são executados inline e retornam o resultado final de áudio no mesmo turno.
Ciclo de vida da tarefa
| Estado | Significado |
|---|---|
queued |
Tarefa criada, aguardando o provedor aceitá-la. |
running |
O provedor está processando (normalmente de 30 segundos a 3 minutos, dependendo do provedor e da duração). |
succeeded |
Faixa pronta; o agente desperta e a publica na conversa. |
failed |
Erro ou timeout do provedor; o agente desperta com detalhes do erro. |
Verifique o status pela CLI:
openclaw tasks listopenclaw tasks show <taskId>openclaw tasks cancel <taskId>Configuração
Seleção de modelo
{ agents: { defaults: { musicGenerationModel: { primary: "google/lyria-3-clip-preview", fallbacks: ["minimax/music-2.6"], }, }, },}Ordem de seleção de provedores
O OpenClaw tenta os provedores nesta ordem:
- Parâmetro
modelda chamada de ferramenta (se o agente especificar um). musicGenerationModel.primaryda configuração.musicGenerationModel.fallbacksem ordem.- Detecção automática usando apenas padrões de provedores com autenticação:
- provedor padrão atual primeiro;
- demais provedores de geração de música registrados em ordem de provider-id.
Se um provedor falhar, o próximo candidato é tentado automaticamente. Se todos falharem, o erro inclui detalhes de cada tentativa.
Defina agents.defaults.mediaGenerationAutoProviderFallback: false para usar apenas
entradas explícitas de model, primary e fallbacks.
Observações de provedores
ComfyUI
Orientado por workflow e depende do grafo configurado mais o mapeamento de nós
para campos de prompt/saída. O Plugin comfy incluído se conecta à
ferramenta compartilhada music_generate por meio do registro de provedores
de geração de música.
Google (Lyria 3)
Usa geração em lote do Lyria 3. O fluxo incluído atual oferece suporte a prompt, texto de letra opcional e imagens de referência opcionais.
MiniMax
Usa o endpoint em lote music_generation. Oferece suporte a prompt, letras
opcionais, modo instrumental, direcionamento de duração e saída mp3 por meio de
autenticação por chave de API minimax ou OAuth minimax-portal.
Escolhendo o caminho certo
- Com provedor compartilhado quando você quer seleção de modelo, failover de provedor e o fluxo assíncrono integrado de tarefa/status.
- Caminho de Plugin (ComfyUI) quando você precisa de um grafo de workflow personalizado ou de um provedor que não faz parte do recurso compartilhado incluído de música.
Se você estiver depurando comportamento específico do ComfyUI, consulte ComfyUI. Se você estiver depurando comportamento de provedor compartilhado, comece por Google (Gemini) ou MiniMax.
Modos de recurso do provedor
O contrato compartilhado de geração de música oferece suporte a declarações explícitas de modo:
generatepara geração apenas por prompt.editquando a solicitação inclui uma ou mais imagens de referência.
Novas implementações de provedor devem preferir blocos de modo explícitos:
capabilities: { generate: { maxTracks: 1, supportsLyrics: true, supportsFormat: true, }, edit: { enabled: true, maxTracks: 1, maxInputImages: 1, supportsFormat: true, },}Campos flat legados como maxInputImages, supportsLyrics e
supportsFormat não são suficientes para anunciar suporte a edição. Provedores
devem declarar generate e edit explicitamente para que testes live, testes de contrato
e a ferramenta compartilhada music_generate possam validar o suporte a modos
deterministicamente.
Testes live
Cobertura live opcional para os provedores compartilhados incluídos:
OPENCLAW_LIVE_TEST=1 pnpm test:live -- extensions/music-generation-providers.live.test.tsWrapper do repositório:
pnpm test:live:media musicEste arquivo live carrega variáveis de ambiente de provedor ausentes de ~/.profile, prefere
chaves de API live/env a perfis de autenticação armazenados por padrão e executa tanto
a cobertura de generate quanto a de edit declarada quando o provedor habilita o
modo de edição. Cobertura hoje:
google:generatemaiseditminimax: apenasgeneratecomfy: cobertura live separada do Comfy, não a varredura compartilhada de provedores
Ative a cobertura live para o caminho de música ComfyUI incluído:
OPENCLAW_LIVE_TEST=1 COMFY_LIVE_TEST=1 pnpm test:live -- extensions/comfy/comfy.live.test.tsO arquivo live do Comfy também cobre fluxos de trabalho de imagem e vídeo do comfy quando essas seções estão configuradas.
Relacionado
- Tarefas em segundo plano — acompanhamento de tarefas para execuções desanexadas de
music_generate - ComfyUI
- Referência de configuração — configuração de
musicGenerationModel - Google (Gemini)
- MiniMax
- Modelos — configuração de modelos e failover
- Visão geral das ferramentas