Tools

Pembuatan musik

Alat music_generate memungkinkan agen membuat musik atau audio melalui kapabilitas pembuatan musik bersama dengan penyedia yang dikonfigurasi — Google, MiniMax, dan ComfyUI yang dikonfigurasi alur kerja saat ini.

Untuk eksekusi agen berbasis sesi, OpenClaw memulai pembuatan musik sebagai tugas latar belakang, melacaknya di catatan tugas, lalu membangunkan agen lagi ketika trek sudah siap agar agen dapat memberi tahu pengguna dan melampirkan audio yang sudah selesai. Dalam obrolan grup/saluran yang menggunakan pengiriman terlihat hanya melalui alat pesan, agen meneruskan hasil melalui alat pesan. Jika agen penyelesaian hanya menulis balasan akhir privat, OpenClaw melakukan fallback ke pengiriman saluran langsung dengan media yang dihasilkan. Pemicu bangun penyelesaian secara eksplisit memperingatkan agen bahwa balasan akhir normal bersifat privat dalam rute tersebut.

Mulai cepat

Didukung penyedia bersama

  • Konfigurasikan autentikasi

    Tetapkan kunci API untuk setidaknya satu penyedia — misalnya GEMINI_API_KEY atau MINIMAX_API_KEY.

  • Pilih model default (opsional)

    {
      agents: {
        defaults: {
          musicGenerationModel: {
            primary: "google/lyria-3-clip-preview",
          },
        },
      },
    }
    
  • Minta agen

    "Generate an upbeat synthpop track about a night drive through a neon city."

    Agen memanggil music_generate secara otomatis. Tidak perlu allow-list alat.

  • Untuk konteks sinkron langsung tanpa eksekusi agen berbasis sesi, alat bawaan tetap melakukan fallback ke pembuatan inline dan mengembalikan jalur media akhir dalam hasil alat.

    Alur kerja ComfyUI

  • Konfigurasikan alur kerja

    Konfigurasikan plugins.entries.comfy.config.music dengan JSON alur kerja dan node prompt/output.

  • Autentikasi cloud (opsional)

    Untuk Comfy Cloud, tetapkan COMFY_API_KEY atau COMFY_CLOUD_API_KEY.

  • Panggil alat

    /tool music_generate prompt="Warm ambient synth loop with soft tape texture"
    
  • Contoh prompt:

    Generate a cinematic piano track with soft strings and no vocals.
    
    Generate an energetic chiptune loop about launching a rocket at sunrise.
    

    Penyedia yang didukung

    Penyedia Model default Input referensi Kontrol yang didukung Autentikasi
    ComfyUI workflow Hingga 1 gambar Musik atau audio yang ditentukan alur kerja COMFY_API_KEY, COMFY_CLOUD_API_KEY
    Google lyria-3-clip-preview Hingga 10 gambar lyrics, instrumental, format GEMINI_API_KEY, GOOGLE_API_KEY
    MiniMax music-2.6 Tidak ada lyrics, instrumental, durationSeconds, format=mp3 MINIMAX_API_KEY atau OAuth MiniMax

    Matriks kapabilitas

    Kontrak mode eksplisit yang digunakan oleh music_generate, pengujian kontrak, dan sweep live bersama:

    Penyedia generate edit Batas edit Lane live bersama
    ComfyUI 1 gambar Tidak dalam sweep bersama; dicakup oleh extensions/comfy/comfy.live.test.ts
    Google 10 gambar generate, edit
    MiniMax Tidak ada generate

    Gunakan action: "list" untuk memeriksa penyedia dan model bersama yang tersedia saat runtime:

    /tool music_generate action=list
    

    Gunakan action: "status" untuk memeriksa tugas musik berbasis sesi yang aktif:

    /tool music_generate action=status
    

    Contoh pembuatan langsung:

    /tool music_generate prompt="Dreamy lo-fi hip hop with vinyl texture and gentle rain" instrumental=true
    

    Parameter alat

    promptstringrequired

    Prompt pembuatan musik. Wajib untuk action: "generate".

    action"generate" | "status" | "list"

    "status" mengembalikan tugas sesi saat ini; "list" memeriksa penyedia.

    modelstring

    Override penyedia/model (misalnya google/lyria-3-pro-preview, comfy/workflow).

    lyricsstring

    Lirik opsional ketika penyedia mendukung input lirik eksplisit.

    instrumentalboolean

    Minta output khusus instrumental ketika penyedia mendukungnya.

    imagestring

    Jalur atau URL gambar referensi tunggal.

    imagesstring[]

    Beberapa gambar referensi (hingga 10 pada penyedia yang mendukung).

    durationSecondsnumber

    Durasi target dalam detik ketika penyedia mendukung petunjuk durasi.

    format"mp3" | "wav"

    Petunjuk format output ketika penyedia mendukungnya.

    filenamestring
    timeoutMsnumber

    Perilaku asinkron

    Pembuatan musik berbasis sesi berjalan sebagai tugas latar belakang:

    • Tugas latar belakang: music_generate membuat tugas latar belakang, segera mengembalikan respons dimulai/tugas, dan memposting trek yang selesai nanti dalam pesan agen lanjutan.
    • Pencegahan duplikasi: saat tugas berstatus queued atau running, panggilan music_generate berikutnya dalam sesi yang sama mengembalikan status tugas alih-alih memulai pembuatan lain. Gunakan action: "status" untuk memeriksa secara eksplisit.
    • Pencarian status: openclaw tasks list atau openclaw tasks show <taskId> memeriksa status antrean, berjalan, dan terminal.
    • Pemicu bangun penyelesaian: OpenClaw menyuntikkan event penyelesaian internal kembali ke sesi yang sama agar model dapat menulis tindak lanjut yang terlihat pengguna sendiri.
    • Petunjuk prompt: giliran pengguna/manual berikutnya dalam sesi yang sama mendapatkan petunjuk runtime kecil ketika tugas musik sudah berjalan, sehingga model tidak memanggil music_generate lagi secara membabi buta.
    • Fallback tanpa sesi: konteks langsung/lokal tanpa sesi agen nyata berjalan inline dan mengembalikan hasil audio akhir dalam giliran yang sama.

    Siklus hidup tugas

    Status Makna
    queued Tugas dibuat, menunggu penyedia menerimanya.
    running Penyedia sedang memproses (biasanya 30 detik hingga 3 menit tergantung penyedia dan durasi).
    succeeded Trek siap; agen bangun dan mempostingnya ke percakapan.
    failed Error penyedia atau timeout; agen bangun dengan detail error.

    Periksa status dari CLI:

    openclaw tasks list
    openclaw tasks show <taskId>
    openclaw tasks cancel <taskId>
    

    Konfigurasi

    Pemilihan model

    {
      agents: {
        defaults: {
          musicGenerationModel: {
            primary: "google/lyria-3-clip-preview",
            fallbacks: ["minimax/music-2.6"],
          },
        },
      },
    }
    

    Urutan pemilihan penyedia

    OpenClaw mencoba penyedia dalam urutan ini:

    1. Parameter model dari panggilan alat (jika agen menentukannya).
    2. musicGenerationModel.primary dari konfigurasi.
    3. musicGenerationModel.fallbacks secara berurutan.
    4. Deteksi otomatis hanya menggunakan default penyedia yang didukung autentikasi:
      • penyedia default saat ini terlebih dahulu;
      • penyedia pembuatan musik terdaftar yang tersisa dalam urutan id penyedia.

    Jika penyedia gagal, kandidat berikutnya dicoba secara otomatis. Jika semuanya gagal, error menyertakan detail dari setiap percobaan.

    Tetapkan agents.defaults.mediaGenerationAutoProviderFallback: false untuk hanya menggunakan entri model, primary, dan fallbacks eksplisit.

    Catatan penyedia

    ComfyUI

    Didorong alur kerja dan bergantung pada graph yang dikonfigurasi beserta pemetaan node untuk bidang prompt/output. Plugin comfy bawaan terhubung ke alat music_generate bersama melalui registri penyedia pembuatan musik.

    Google (Lyria 3)

    Menggunakan pembuatan batch Lyria 3. Alur bawaan saat ini mendukung prompt, teks lirik opsional, dan gambar referensi opsional.

    MiniMax

    Menggunakan endpoint batch music_generation. Mendukung prompt, lirik opsional, mode instrumental, pengaturan durasi, dan output mp3 melalui autentikasi kunci API minimax atau OAuth minimax-portal.

    Memilih jalur yang tepat

    • Didukung penyedia bersama ketika Anda menginginkan pemilihan model, failover penyedia, dan alur tugas/status asinkron bawaan.
    • Jalur Plugin (ComfyUI) ketika Anda memerlukan graph alur kerja khusus atau penyedia yang bukan bagian dari kapabilitas musik bawaan bersama.

    Jika Anda sedang men-debug perilaku khusus ComfyUI, lihat ComfyUI. Jika Anda sedang men-debug perilaku penyedia bersama, mulai dengan Google (Gemini) atau MiniMax.

    Mode kapabilitas penyedia

    Kontrak pembuatan musik bersama mendukung deklarasi mode eksplisit:

    • generate untuk pembuatan hanya dengan prompt.
    • edit ketika permintaan menyertakan satu atau beberapa gambar referensi.

    Implementasi penyedia baru sebaiknya mengutamakan blok mode eksplisit:

    capabilities: {
      generate: {
        maxTracks: 1,
        supportsLyrics: true,
        supportsFormat: true,
      },
      edit: {
        enabled: true,
        maxTracks: 1,
        maxInputImages: 1,
        supportsFormat: true,
      },
    }
    

    Bidang flat lama seperti maxInputImages, supportsLyrics, dan supportsFormat tidak cukup untuk mengiklankan dukungan edit. Penyedia harus mendeklarasikan generate dan edit secara eksplisit agar pengujian live, pengujian kontrak, dan alat music_generate bersama dapat memvalidasi dukungan mode secara deterministik.

    Pengujian live

    Cakupan live opt-in untuk penyedia bawaan bersama:

    OPENCLAW_LIVE_TEST=1 pnpm test:live -- extensions/music-generation-providers.live.test.ts
    

    Wrapper repo:

    pnpm test:live:media music
    

    File live ini memuat env var penyedia yang hilang dari ~/.profile, mengutamakan kunci API live/env daripada profil autentikasi tersimpan secara default, dan menjalankan cakupan generate serta edit yang dideklarasikan ketika penyedia mengaktifkan mode edit. Cakupan saat ini:

    • google: generate dan edit
    • minimax: hanya generate
    • comfy: cakupan live Comfy terpisah, bukan sweep penyedia bersama

    Cakupan live opt-in untuk jalur musik ComfyUI bawaan:

    OPENCLAW_LIVE_TEST=1 COMFY_LIVE_TEST=1 pnpm test:live -- extensions/comfy/comfy.live.test.ts
    

    File live Comfy juga mencakup alur kerja gambar dan video comfy ketika bagian-bagian tersebut dikonfigurasi.

    Terkait