Regional platforms

bot QQ

QQ Bot terhubung ke OpenClaw melalui QQ Bot API resmi (Gateway WebSocket). Plugin ini mendukung obrolan privat C2C, @pesan grup, dan pesan saluran guild dengan media kaya (gambar, suara, video, file).

Status: Plugin yang dapat diunduh. Pesan langsung, obrolan grup, saluran guild, dan media didukung. Reaksi dan utas tidak didukung.

Instal

Instal QQ Bot sebelum penyiapan:

openclaw plugins install @openclaw/qqbot

Penyiapan

  1. Buka QQ Open Platform dan pindai kode QR dengan QQ di ponsel Anda untuk mendaftar / masuk.
  2. Klik Create Bot untuk membuat bot QQ baru.
  3. Temukan AppID dan AppSecret di halaman pengaturan bot lalu salin.

AppSecret tidak disimpan sebagai teks polos — jika Anda meninggalkan halaman tanpa menyimpannya, Anda harus membuat ulang yang baru.

  1. Tambahkan saluran:
openclaw channels add --channel qqbot --token "AppID:AppSecret"
  1. Mulai ulang Gateway.

Jalur penyiapan interaktif:

openclaw channels add
openclaw configure --section channels

Konfigurasi

Konfigurasi minimal:

{
  channels: {
    qqbot: {
      enabled: true,
      appId: "YOUR_APP_ID",
      clientSecret: "YOUR_APP_SECRET",
    },
  },
}

Variabel lingkungan akun bawaan:

  • QQBOT_APP_ID
  • QQBOT_CLIENT_SECRET

AppSecret berbasis file:

{
  channels: {
    qqbot: {
      enabled: true,
      appId: "YOUR_APP_ID",
      clientSecretFile: "/path/to/qqbot-secret.txt",
    },
  },
}

AppSecret SecretRef lingkungan:

{
  channels: {
    qqbot: {
      enabled: true,
      appId: "YOUR_APP_ID",
      clientSecret: { source: "env", provider: "default", id: "QQBOT_CLIENT_SECRET" },
    },
  },
}

Catatan:

  • Fallback lingkungan hanya berlaku untuk akun QQ Bot bawaan.
  • openclaw channels add --channel qqbot --token-file ... hanya menyediakan AppSecret; AppID harus sudah diatur di konfigurasi atau QQBOT_APP_ID.
  • clientSecret juga menerima masukan SecretRef, bukan hanya string teks polos.
  • String penanda lama secretref:/... bukan nilai clientSecret yang valid; gunakan objek SecretRef terstruktur seperti contoh di atas.

Penyiapan multi-akun

Jalankan beberapa QQ bot dalam satu instance OpenClaw:

{
  channels: {
    qqbot: {
      enabled: true,
      appId: "111111111",
      clientSecret: "secret-of-bot-1",
      accounts: {
        bot2: {
          enabled: true,
          appId: "222222222",
          clientSecret: "secret-of-bot-2",
        },
      },
    },
  },
}

Setiap akun meluncurkan koneksi WebSocket-nya sendiri dan memelihara cache token independen (diisolasi berdasarkan appId).

Tambahkan bot kedua melalui CLI:

openclaw channels add --channel qqbot --account bot2 --token "222222222:secret-of-bot-2"

Obrolan grup

Dukungan obrolan grup QQ Bot menggunakan OpenID grup QQ, bukan nama tampilan. Tambahkan bot ke grup, lalu sebut bot tersebut atau konfigurasikan grup agar berjalan tanpa sebutan.

{
  channels: {
    qqbot: {
      groupPolicy: "allowlist",
      groupAllowFrom: ["member_openid"],
      groups: {
        "*": {
          requireMention: true,
          historyLimit: 50,
          toolPolicy: "restricted",
        },
        GROUP_OPENID: {
          name: "Release room",
          requireMention: false,
          ignoreOtherMentions: true,
          historyLimit: 20,
          prompt: "Keep replies short and operational.",
        },
      },
    },
  },
}

groups["*"] menetapkan bawaan untuk setiap grup, dan entri konkret groups.GROUP_OPENID menimpa bawaan tersebut untuk satu grup. Pengaturan grup mencakup:

  • requireMention: mewajibkan @mention sebelum bot membalas. Bawaan: true.
  • ignoreOtherMentions: buang pesan yang menyebut orang lain tetapi bukan bot.
  • historyLimit: simpan pesan grup non-sebutan terbaru sebagai konteks untuk giliran berikutnya yang menyebut bot. Atur 0 untuk menonaktifkan.
  • toolPolicy: full, restricted, atau none untuk alat bercakupan grup.
  • name: label ramah yang digunakan dalam log dan konteks grup.
  • prompt: prompt perilaku per grup yang ditambahkan ke konteks agen.

Mode aktivasi adalah mention dan always. requireMention: true dipetakan ke mention; requireMention: false dipetakan ke always. Penggantian aktivasi tingkat sesi, jika ada, mengalahkan konfigurasi.

Antrean masuk bersifat per rekan. Rekan grup mendapat batas antrean yang lebih besar, menjaga pesan manusia tetap di depan percakapan buatan bot saat penuh, dan menggabungkan ledakan pesan grup normal menjadi satu giliran dengan atribusi. Perintah slash tetap berjalan satu per satu.

Suara (STT / TTS)

Dukungan STT dan TTS menggunakan konfigurasi dua tingkat dengan fallback prioritas:

Pengaturan Khusus Plugin Fallback kerangka kerja
STT channels.qqbot.stt tools.media.audio.models[0]
TTS channels.qqbot.tts, channels.qqbot.accounts.<id>.tts messages.tts
{
  channels: {
    qqbot: {
      stt: {
        provider: "your-provider",
        model: "your-stt-model",
      },
      tts: {
        provider: "your-provider",
        model: "your-tts-model",
        voice: "your-voice",
      },
      accounts: {
        "qq-main": {
          tts: {
            providers: {
              openai: { voice: "shimmer" },
            },
          },
        },
      },
    },
  },
}

Atur enabled: false pada salah satunya untuk menonaktifkan. Penggantian TTS tingkat akun menggunakan bentuk yang sama seperti messages.tts dan melakukan deep-merge di atas konfigurasi TTS saluran/global.

Lampiran suara QQ yang masuk diekspos ke agen sebagai metadata media audio sambil menjaga file suara mentah tetap berada di luar MediaPaths generik. Balasan teks polos [[audio_as_voice]] menyintesis TTS dan mengirim pesan suara QQ asli ketika TTS dikonfigurasi.

Perilaku unggah/transkode audio keluar juga dapat disesuaikan dengan channels.qqbot.audioFormatPolicy:

  • sttDirectFormats
  • uploadDirectFormats
  • transcodeEnabled

Format target

Format Deskripsi
qqbot:c2c:OPENID Obrolan privat (C2C)
qqbot:group:GROUP_OPENID Obrolan grup
qqbot:channel:CHANNEL_ID Saluran guild

Setiap bot memiliki kumpulan OpenID pengguna sendiri. OpenID yang diterima oleh Bot A tidak dapat digunakan untuk mengirim pesan melalui Bot B.

Perintah slash

Perintah bawaan yang dicegat sebelum antrean AI:

Perintah Deskripsi
/bot-ping Uji latensi
/bot-version Tampilkan versi kerangka kerja OpenClaw
/bot-help Cantumkan semua perintah
/bot-me Tampilkan ID pengguna QQ pengirim (openid) untuk penyiapan allowFrom/groupAllowFrom
/bot-upgrade Tampilkan tautan panduan peningkatan QQBot
/bot-logs Ekspor log Gateway terbaru sebagai file
/bot-approve Setujui tindakan QQ Bot yang tertunda (misalnya, mengonfirmasi unggahan C2C atau grup) melalui alur asli.

Tambahkan ? ke perintah apa pun untuk bantuan penggunaan (misalnya /bot-upgrade ?).

Perintah admin (/bot-me, /bot-upgrade, /bot-logs, /bot-clear-storage, /bot-streaming, /bot-approve) hanya untuk pesan langsung dan mengharuskan openid pengirim berada dalam daftar allowFrom eksplisit non-wildcard. Wildcard allowFrom: ["*"] mengizinkan obrolan tetapi tidak memberikan akses perintah admin. Pesan grup dicocokkan terhadap groupAllowFrom terlebih dahulu dan fallback ke allowFrom. Menjalankan perintah admin di grup mengembalikan petunjuk, bukan mengabaikannya diam-diam.

Arsitektur mesin

QQ Bot dikirim sebagai mesin mandiri di dalam Plugin:

  • Setiap akun memiliki stack sumber daya terisolasi (koneksi WebSocket, klien API, cache token, root penyimpanan media) yang dikunci berdasarkan appId. Akun tidak pernah berbagi status masuk/keluar.
  • Pencatat multi-akun memberi tag baris log dengan akun pemilik agar diagnostik tetap dapat dipisahkan saat Anda menjalankan beberapa bot dalam satu Gateway.
  • Jalur masuk, keluar, dan jembatan Gateway berbagi satu root payload media di bawah ~/.openclaw/media, sehingga unggahan, unduhan, dan cache transkode berada di bawah satu direktori terlindungi, bukan pohon per subsistem.
  • Pengiriman media kaya melewati satu jalur sendMedia untuk target C2C dan grup. File lokal dan buffer di atas ambang file besar menggunakan endpoint unggah bertahap QQ, sedangkan payload yang lebih kecil menggunakan API media sekali jalan.
  • Kredensial dapat dicadangkan dan dipulihkan sebagai bagian dari snapshot kredensial OpenClaw standar; mesin memasang kembali stack sumber daya setiap akun saat pemulihan tanpa memerlukan pasangan kode QR baru.

Onboarding kode QR

Sebagai alternatif untuk menempelkan AppID:AppSecret secara manual, mesin mendukung alur onboarding kode QR untuk menautkan QQ Bot ke OpenClaw:

  1. Jalankan jalur penyiapan QQ Bot (misalnya openclaw channels add --channel qqbot) dan pilih alur kode QR saat diminta.
  2. Pindai kode QR yang dihasilkan dengan aplikasi ponsel yang terikat ke QQ Bot target.
  3. Setujui pemasangan di ponsel. OpenClaw menyimpan kredensial yang dikembalikan ke credentials/ di bawah cakupan akun yang benar.

Prompt persetujuan yang dibuat oleh bot itu sendiri (misalnya, alur "izinkan tindakan ini?" yang diekspos oleh QQ Bot API) muncul sebagai prompt OpenClaw asli yang dapat Anda terima dengan /bot-approve, bukan membalas melalui klien QQ mentah.

Pemecahan masalah

  • Bot membalas "gone to Mars": kredensial belum dikonfigurasi atau Gateway belum dimulai.
  • Tidak ada pesan masuk: verifikasi appId dan clientSecret sudah benar, dan bot diaktifkan di QQ Open Platform.
  • Balasan diri berulang: OpenClaw mencatat indeks referensi keluar QQ sebagai buatan bot dan mengabaikan peristiwa masuk yang msgIdx saat ini cocok dengan akun bot yang sama. Ini mencegah loop gema platform sambil tetap memungkinkan pengguna mengutip atau membalas pesan bot sebelumnya.
  • Penyiapan dengan --token-file masih menampilkan belum dikonfigurasi: --token-file hanya mengatur AppSecret. Anda tetap memerlukan appId di konfigurasi atau QQBOT_APP_ID.
  • Pesan proaktif tidak tiba: QQ dapat mencegat pesan yang dimulai bot jika pengguna belum berinteraksi baru-baru ini.
  • Suara tidak ditranskripsikan: pastikan STT dikonfigurasi dan penyedia dapat dijangkau.

Terkait