Per-channel kunci konfigurasi di bawahDocumentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
channels.*. Mencakup akses DM dan grup,
penyiapan multi-akun, gating mention, dan kunci per kanal untuk Slack, Discord,
Telegram, WhatsApp, Matrix, iMessage, serta Plugin kanal bawaan lainnya.
Untuk agen, alat, runtime Gateway, dan kunci tingkat atas lainnya, lihat
Referensi konfigurasi.
Kanal
Setiap kanal dimulai otomatis ketika bagian konfigurasinya ada (kecualienabled: false).
Akses DM dan grup
Semua kanal mendukung kebijakan DM dan kebijakan grup:| Kebijakan DM | Perilaku |
|---|---|
pairing (default) | Pengirim tidak dikenal mendapat kode pairing sekali pakai; pemilik harus menyetujui |
allowlist | Hanya pengirim dalam allowFrom (atau penyimpanan izin yang sudah dipairing) |
open | Izinkan semua DM masuk (memerlukan allowFrom: ["*"]) |
disabled | Abaikan semua DM masuk |
| Kebijakan grup | Perilaku |
|---|---|
allowlist (default) | Hanya grup yang cocok dengan daftar izin yang dikonfigurasi |
open | Lewati daftar izin grup (gating mention tetap berlaku) |
disabled | Blokir semua pesan grup/room |
channels.defaults.groupPolicy menetapkan default ketika groupPolicy milik penyedia tidak diatur.
Kode pairing kedaluwarsa setelah 1 jam. Permintaan pairing DM yang tertunda dibatasi 3 per kanal.
Jika blok penyedia tidak ada sama sekali (channels.<provider> tidak ada), kebijakan grup runtime kembali ke allowlist (fail-closed) dengan peringatan saat startup.Override model kanal
Gunakanchannels.modelByChannel untuk menyematkan ID kanal tertentu ke sebuah model. Nilai menerima provider/model atau alias model yang dikonfigurasi. Pemetaan kanal berlaku ketika sebuah sesi belum memiliki override model (misalnya, diatur melalui /model).
Default kanal dan Heartbeat
Gunakanchannels.defaults untuk kebijakan grup bersama dan perilaku Heartbeat lintas penyedia:
channels.defaults.groupPolicy: kebijakan grup fallback ketikagroupPolicytingkat penyedia tidak diatur.channels.defaults.contextVisibility: mode visibilitas konteks tambahan default untuk semua kanal. Nilai:all(default, sertakan semua konteks kutipan/thread/riwayat),allowlist(hanya sertakan konteks dari pengirim yang diizinkan),allowlist_quote(sama seperti allowlist tetapi pertahankan konteks kutipan/balasan eksplisit). Override per kanal:channels.<channel>.contextVisibility.channels.defaults.heartbeat.showOk: sertakan status kanal sehat dalam output Heartbeat.channels.defaults.heartbeat.showAlerts: sertakan status terdegradasi/error dalam output Heartbeat.channels.defaults.heartbeat.useIndicator: render output Heartbeat ringkas bergaya indikator.
WhatsApp Multi-akun
WhatsApp Multi-akun
- Perintah keluar menggunakan akun
defaultsecara default jika ada; jika tidak, ID akun pertama yang dikonfigurasi (diurutkan). - Opsional
channels.whatsapp.defaultAccountmeng-override pilihan akun default fallback tersebut ketika cocok dengan ID akun yang dikonfigurasi. - Direktori auth Baileys akun tunggal lama dimigrasikan oleh
openclaw doctorkewhatsapp/default. - Override per akun:
channels.whatsapp.accounts.<id>.sendReadReceipts,channels.whatsapp.accounts.<id>.dmPolicy,channels.whatsapp.accounts.<id>.allowFrom.
Telegram
- Token bot:
channels.telegram.botTokenatauchannels.telegram.tokenFile(hanya file reguler; symlink ditolak), denganTELEGRAM_BOT_TOKENsebagai fallback untuk akun default. apiRoothanya root Telegram Bot API. Gunakanhttps://api.telegram.orgatau root self-hosted/proxy Anda, bukanhttps://api.telegram.org/bot<TOKEN>;openclaw doctor --fixmenghapus akhiran/bot<TOKEN>yang tidak sengaja tertinggal.- Opsional
channels.telegram.defaultAccountmeng-override pilihan akun default ketika cocok dengan ID akun yang dikonfigurasi. - Dalam penyiapan multi-akun (2+ ID akun), tetapkan default eksplisit (
channels.telegram.defaultAccountatauchannels.telegram.accounts.default) untuk menghindari routing fallback;openclaw doctormemperingatkan ketika ini hilang atau tidak valid. configWrites: falsememblokir penulisan konfigurasi yang dimulai Telegram (migrasi ID supergroup,/config set|unset).- Entri
bindings[]tingkat atas dengantype: "acp"mengonfigurasi binding ACP persisten untuk topik forum (gunakanchatId:topic:topicIdkanonis dalammatch.peer.id). Semantik field dibagikan di Agen ACP. - Pratinjau stream Telegram menggunakan
sendMessage+editMessageText(berfungsi di chat langsung dan grup). - Kebijakan retry: lihat Kebijakan retry.
Discord
- Token:
channels.discord.token, denganDISCORD_BOT_TOKENsebagai fallback untuk akun default. - Panggilan keluar langsung yang menyediakan Discord
tokeneksplisit menggunakan token tersebut untuk panggilan itu; pengaturan percobaan ulang/kebijakan akun tetap berasal dari akun yang dipilih dalam snapshot runtime aktif. channels.discord.defaultAccountopsional menimpa pemilihan akun default saat cocok dengan id akun yang dikonfigurasi.- Gunakan
user:<id>(DM) atauchannel:<id>(saluran guild) untuk target pengiriman; ID numerik polos ditolak. - Slug guild menggunakan huruf kecil dengan spasi diganti
-; kunci saluran menggunakan nama yang sudah dijadikan slug (tanpa#). Sebaiknya gunakan ID guild. - Pesan yang ditulis bot diabaikan secara default.
allowBots: truemengaktifkannya; gunakanallowBots: "mentions"untuk hanya menerima pesan bot yang menyebut bot tersebut (pesan sendiri tetap difilter). channels.discord.guilds.<id>.ignoreOtherMentions(dan penimpaan saluran) membuang pesan yang menyebut pengguna atau peran lain tetapi bukan bot tersebut (tidak termasuk @everyone/@here).channels.discord.mentionAliasesmemetakan teks@handlekeluar yang stabil ke ID pengguna Discord sebelum dikirim, sehingga rekan tim yang dikenal dapat disebut secara deterministik bahkan saat cache direktori sementara kosong. Penimpaan per akun berada di bawahchannels.discord.accounts.<accountId>.mentionAliases.maxLinesPerMessage(default 17) membagi pesan tinggi meskipun kurang dari 2000 karakter.channels.discord.threadBindingsmengontrol perutean terikat thread Discord:enabled: penimpaan Discord untuk fitur sesi terikat thread (/focus,/unfocus,/agents,/session idle,/session max-age, serta pengiriman/perutean terikat)idleHours: penimpaan Discord untuk auto-unfocus karena tidak aktif dalam jam (0menonaktifkan)maxAgeHours: penimpaan Discord untuk usia maksimum keras dalam jam (0menonaktifkan)spawnSessions: sakelar untuksessions_spawn({ thread: true })dan pembuatan/pengikatan thread otomatis dari ACP thread-spawn (default:true)defaultSpawnContext: konteks subagen native untuk spawn terikat thread ("fork"secara default)
- Entri
bindings[]tingkat atas dengantype: "acp"mengonfigurasi pengikatan ACP persisten untuk saluran dan thread (gunakan id saluran/thread dimatch.peer.id). Semantik bidang dibagikan di Agen ACP. channels.discord.ui.components.accentColormengatur warna aksen untuk kontainer Discord components v2.channels.discord.voicemengaktifkan percakapan saluran suara Discord serta penimpaan auto-join + LLM + TTS opsional. Konfigurasi Discord khusus teks membiarkan suara nonaktif secara default; aturchannels.discord.voice.enabled=trueuntuk ikut mengaktifkan.channels.discord.voice.modelsecara opsional menimpa model LLM yang digunakan untuk respons saluran suara Discord.channels.discord.voice.daveEncryptiondanchannels.discord.voice.decryptionFailureTolerancediteruskan ke opsi DAVE@discordjs/voice(truedan24secara default).channels.discord.voice.connectTimeoutMsmengontrol penantian Ready awal@discordjs/voiceuntuk/vc joindan percobaan auto-join (30000secara default).channels.discord.voice.reconnectGraceMsmengontrol berapa lama sesi suara yang terputus boleh memasuki pensinyalan reconnect sebelum OpenClaw menghancurkannya (15000secara default).- Pemutaran suara Discord tidak disela oleh event speaking-start pengguna lain. Untuk menghindari loop umpan balik, OpenClaw mengabaikan tangkapan suara baru saat TTS sedang diputar.
- OpenClaw juga mencoba pemulihan penerimaan suara dengan keluar/bergabung ulang ke sesi suara setelah kegagalan dekripsi berulang.
channels.discord.streamingadalah kunci mode stream kanonis. Discord secara default menggunakanstreaming.mode: "progress"sehingga progres tool/kerja muncul dalam satu pesan pratinjau yang diedit; aturstreaming.mode: "off"untuk menonaktifkannya. Nilai legacystreamModedan booleanstreamingtetap menjadi alias runtime; jalankanopenclaw doctor --fixuntuk menulis ulang konfigurasi persisten.channels.discord.autoPresencememetakan ketersediaan runtime ke presence bot (sehat => online, terdegradasi => idle, habis => dnd) dan mengizinkan penimpaan teks status opsional.channels.discord.dangerouslyAllowNameMatchingmengaktifkan kembali pencocokan nama/tag yang dapat berubah (mode kompatibilitas break-glass).channels.discord.execApprovals: pengiriman persetujuan exec native Discord dan otorisasi pemberi persetujuan.enabled:true,false, atau"auto"(default). Dalam mode auto, persetujuan exec aktif saat pemberi persetujuan dapat di-resolve dariapproversataucommands.ownerAllowFrom.approvers: ID pengguna Discord yang diizinkan menyetujui permintaan exec. Fallback kecommands.ownerAllowFromsaat dihilangkan.agentFilter: allowlist ID agen opsional. Hilangkan untuk meneruskan persetujuan untuk semua agen.sessionFilter: pola kunci sesi opsional (substring atau regex).target: tempat mengirim prompt persetujuan."dm"(default) mengirim ke DM pemberi persetujuan,"channel"mengirim ke saluran asal,"both"mengirim ke keduanya. Saat target mencakup"channel", tombol hanya dapat digunakan oleh pemberi persetujuan yang berhasil di-resolve.cleanupAfterResolve: saattrue, menghapus DM persetujuan setelah disetujui, ditolak, atau timeout.
off (tidak ada), own (pesan bot, default), all (semua pesan), allowlist (dari guilds.<id>.users pada semua pesan).
Google Chat
- JSON akun layanan: inline (
serviceAccount) atau berbasis file (serviceAccountFile). - SecretRef akun layanan juga didukung (
serviceAccountRef). - Fallback env:
GOOGLE_CHAT_SERVICE_ACCOUNTatauGOOGLE_CHAT_SERVICE_ACCOUNT_FILE. - Gunakan
spaces/<spaceId>atauusers/<userId>untuk target pengiriman. channels.googlechat.dangerouslyAllowNameMatchingmengaktifkan kembali pencocokan prinsipal email yang dapat berubah (mode kompatibilitas break-glass).
Slack
- Mode socket memerlukan
botTokendanappToken(SLACK_BOT_TOKEN+SLACK_APP_TOKENuntuk fallback env akun default). - Mode HTTP memerlukan
botTokenplussigningSecret(di root atau per akun). socketModemeneruskan penyetelan transport Socket Mode Slack SDK ke API penerima Bolt publik. Gunakan hanya saat menyelidiki timeout ping/pong atau perilaku websocket kedaluwarsa.botToken,appToken,signingSecret, danuserTokenmenerima string plaintext atau objek SecretRef.- Snapshot akun Slack mengekspos bidang sumber/status per kredensial seperti
botTokenSource,botTokenStatus,appTokenStatus, dan, dalam mode HTTP,signingSecretStatus.configured_unavailableberarti akun dikonfigurasi melalui SecretRef tetapi jalur perintah/runtime saat ini tidak dapat me-resolve nilai secret. configWrites: falsememblokir penulisan konfigurasi yang diinisiasi Slack.channels.slack.defaultAccountopsional menimpa pemilihan akun default saat cocok dengan id akun yang dikonfigurasi.channels.slack.streaming.modeadalah kunci mode stream Slack kanonis.channels.slack.streaming.nativeTransportmengontrol transport streaming native Slack. Nilai legacystreamMode, booleanstreaming, dannativeStreamingtetap menjadi alias runtime; jalankanopenclaw doctor --fixuntuk menulis ulang konfigurasi persisten.unfurlLinksdanunfurlMediameneruskan boolean unfurl tautan dan mediachat.postMessageSlack untuk balasan bot. Hilangkan untuk mempertahankan perilaku default Slack; atur dichannels.slack.accounts.<accountId>untuk menimpa default tingkat atas bagi satu akun.- Gunakan
user:<id>(DM) atauchannel:<id>untuk target pengiriman.
off, own (default), all, allowlist (dari reactionAllowlist).
Isolasi sesi thread: thread.historyScope bersifat per-thread (default) atau dibagikan di seluruh saluran. thread.inheritParent menyalin transkrip saluran induk ke thread baru.
- Streaming native Slack plus status thread “is typing…” bergaya asisten Slack memerlukan target thread balasan. DM tingkat atas tetap berada di luar thread secara default, sehingga masih dapat melakukan streaming melalui pratinjau draf post-and-edit Slack alih-alih menampilkan pratinjau stream/status native bergaya thread.
typingReactionmenambahkan reaksi sementara ke pesan Slack masuk saat balasan sedang berjalan, lalu menghapusnya saat selesai. Gunakan shortcode emoji Slack seperti"hourglass_flowing_sand".channels.slack.execApprovals: pengiriman persetujuan exec native Slack dan otorisasi pemberi persetujuan. Skema sama seperti Discord:enabled(true/false/"auto"),approvers(ID pengguna Slack),agentFilter,sessionFilter, dantarget("dm","channel", atau"both").
| Grup aksi | Default | Catatan |
|---|---|---|
| reactions | aktif | Bereaksi + mencantumkan reaksi |
| messages | aktif | Baca/kirim/edit/hapus |
| pins | aktif | Pin/lepas pin/daftar |
| memberInfo | aktif | Info anggota |
| emojiList | aktif | Daftar emoji kustom |
Mattermost
Mattermost dikirim sebagai Plugin bundel dalam rilis OpenClaw saat ini. Build lama atau kustom dapat menginstal paket npm saat ini denganopenclaw plugins install @openclaw/mattermost. Periksa npmjs.com/package/@openclaw/mattermost untuk dist-tag saat ini sebelum melakukan pin versi.
oncall (merespons pada @-mention, default), onmessage (setiap pesan), onchar (pesan yang diawali prefiks pemicu).
Saat perintah native Mattermost diaktifkan:
commands.callbackPathharus berupa path (misalnya/api/channels/mattermost/command), bukan URL lengkap.commands.callbackUrlharus mengarah ke endpoint Gateway OpenClaw dan dapat dijangkau dari server Mattermost.- Callback slash native diautentikasi dengan token per perintah yang dikembalikan
oleh Mattermost selama pendaftaran slash command. Jika pendaftaran gagal atau tidak ada
perintah yang diaktifkan, OpenClaw menolak callback dengan
Unauthorized: invalid command token. - Untuk host callback privat/tailnet/internal, Mattermost mungkin mengharuskan
ServiceSettings.AllowedUntrustedInternalConnectionsmenyertakan host/domain callback. Gunakan nilai host/domain, bukan URL lengkap. channels.mattermost.configWrites: izinkan atau tolak penulisan konfigurasi yang dimulai Mattermost.channels.mattermost.requireMention: wajibkan@mentionsebelum membalas di saluran.channels.mattermost.groups.<channelId>.requireMention: override per saluran untuk gerbang mention ("*"untuk default).channels.mattermost.defaultAccountopsional meng-override pemilihan akun default saat cocok dengan id akun yang dikonfigurasi.
Signal
off, own (default), all, allowlist (dari reactionAllowlist).
channels.signal.account: sematkan startup saluran ke identitas akun Signal tertentu.channels.signal.configWrites: izinkan atau tolak penulisan konfigurasi yang dimulai Signal.channels.signal.defaultAccountopsional meng-override pemilihan akun default saat cocok dengan id akun yang dikonfigurasi.
iMessage
OpenClaw menjalankanimsg rpc (JSON-RPC melalui stdio). Tidak memerlukan daemon atau port. Ini adalah jalur yang disarankan untuk setup iMessage OpenClaw baru saat host dapat memberikan izin database Messages dan Automation.
Dukungan BlueBubbles telah dihapus. channels.bluebubbles bukan permukaan konfigurasi runtime yang didukung pada OpenClaw saat ini. Migrasikan konfigurasi lama ke channels.imessage; gunakan Penghapusan BlueBubbles dan jalur imsg iMessage untuk versi singkat dan Beralih dari BlueBubbles untuk tabel terjemahan lengkap.
Jika Gateway tidak berjalan di Mac Messages yang sudah masuk, pertahankan channels.imessage.enabled=true dan atur channels.imessage.cliPath ke wrapper SSH yang menjalankan imsg "$@" di Mac tersebut. Path lokal default imsg hanya untuk macOS.
-
channels.imessage.defaultAccountopsional meng-override pemilihan akun default saat cocok dengan id akun yang dikonfigurasi. - Memerlukan Full Disk Access ke DB Messages.
-
Utamakan target
chat_id:<id>. Gunakanimsg chats --limit 20untuk mencantumkan chat. -
cliPathdapat menunjuk ke wrapper SSH; aturremoteHost(hostatauuser@host) untuk pengambilan lampiran melalui SCP. -
attachmentRootsdanremoteAttachmentRootsmembatasi path lampiran masuk (default:/Users/*/Library/Messages/Attachments). -
SCP menggunakan pemeriksaan host-key ketat, jadi pastikan kunci host relay sudah ada di
~/.ssh/known_hosts. -
channels.imessage.configWrites: izinkan atau tolak penulisan konfigurasi yang dimulai iMessage. -
channels.imessage.actions.*: aktifkan tindakan API privat yang juga dibatasi olehimsg status/openclaw channels status --probe. -
channels.imessage.includeAttachmentsnonaktif secara default; atur ketruesebelum mengharapkan media masuk dalam giliran agen. -
channels.imessage.catchup.enabled: ikut serta untuk memutar ulang pesan masuk yang tiba saat Gateway tidak aktif. -
channels.imessage.groups: registri grup dan pengaturan per grup. DengangroupPolicy: "allowlist", konfigurasikan kuncichat_ideksplisit atau entri wildcard"*"agar pesan grup dapat melewati gerbang registri. -
Entri
bindings[]tingkat atas dengantype: "acp"dapat mengikat percakapan iMessage ke sesi ACP persisten. Gunakan handle yang dinormalisasi atau target chat eksplisit (chat_id:*,chat_guid:*,chat_identifier:*) dimatch.peer.id. Semantik field bersama: Agen ACP.
Contoh wrapper SSH iMessage
Contoh wrapper SSH iMessage
Matrix
Matrix didukung Plugin dan dikonfigurasi di bawahchannels.matrix.
- Autentikasi token menggunakan
accessToken; autentikasi kata sandi menggunakanuserId+password. channels.matrix.proxymerutekan lalu lintas HTTP Matrix melalui proxy HTTP(S) eksplisit. Akun bernama dapat meng-override-nya denganchannels.matrix.accounts.<id>.proxy.channels.matrix.network.dangerouslyAllowPrivateNetworkmengizinkan homeserver privat/internal.proxydan opt-in jaringan ini adalah kontrol independen.channels.matrix.defaultAccountmemilih akun yang disukai dalam setup multi-akun.channels.matrix.autoJoindefault keoff, sehingga room undangan dan undangan baru bergaya DM diabaikan sampai Anda mengaturautoJoin: "allowlist"denganautoJoinAllowlistatauautoJoin: "always".channels.matrix.execApprovals: pengiriman persetujuan exec native Matrix dan otorisasi pemberi persetujuan.enabled:true,false, atau"auto"(default). Dalam mode auto, persetujuan exec aktif saat pemberi persetujuan dapat diselesaikan dariapproversataucommands.ownerAllowFrom.approvers: ID pengguna Matrix (misalnya@owner:example.org) yang diizinkan menyetujui permintaan exec.agentFilter: allowlist ID agen opsional. Abaikan untuk meneruskan persetujuan bagi semua agen.sessionFilter: pola kunci sesi opsional (substring atau regex).target: tempat mengirim prompt persetujuan."dm"(default),"channel"(room asal), atau"both".- Override per akun:
channels.matrix.accounts.<id>.execApprovals.
channels.matrix.dm.sessionScopemengontrol cara DM Matrix dikelompokkan ke sesi:per-user(default) berbagi berdasarkan peer yang dirutekan, sedangkanper-roommengisolasi setiap room DM.- Probe status Matrix dan lookup direktori live menggunakan kebijakan proxy yang sama dengan lalu lintas runtime.
- Konfigurasi Matrix lengkap, aturan penargetan, dan contoh setup didokumentasikan di Matrix.
Microsoft Teams
Microsoft Teams didukung Plugin dan dikonfigurasi di bawahchannels.msteams.
- Path kunci inti yang dicakup di sini:
channels.msteams,channels.msteams.configWrites. - Konfigurasi Teams lengkap (kredensial, webhook, kebijakan DM/grup, override per tim/per saluran) didokumentasikan di Microsoft Teams.
IRC
IRC didukung Plugin dan dikonfigurasi di bawahchannels.irc.
- Path kunci inti yang dicakup di sini:
channels.irc,channels.irc.dmPolicy,channels.irc.configWrites,channels.irc.nickserv.*. channels.irc.defaultAccountopsional meng-override pemilihan akun default saat cocok dengan id akun yang dikonfigurasi.- Konfigurasi saluran IRC lengkap (host/port/TLS/saluran/allowlist/gerbang mention) didokumentasikan di IRC.
Multi-akun (semua saluran)
Jalankan beberapa akun per saluran (masing-masing denganaccountId sendiri):
defaultdigunakan saataccountIddihilangkan (CLI + perutean).- Token env hanya berlaku untuk akun default.
- Pengaturan saluran dasar berlaku untuk semua akun kecuali di-override per akun.
- Gunakan
bindings[].match.accountIduntuk merutekan setiap akun ke agen yang berbeda. - Jika Anda menambahkan akun non-default melalui
openclaw channels add(atau onboarding saluran) saat masih menggunakan konfigurasi saluran tingkat atas akun tunggal, OpenClaw terlebih dahulu mempromosikan nilai akun tunggal tingkat atas bercakupan akun ke peta akun saluran agar akun asli tetap berfungsi. Sebagian besar saluran memindahkannya kechannels.<channel>.accounts.default; Matrix dapat mempertahankan target bernama/default yang cocok yang sudah ada. - Binding khusus saluran yang sudah ada (tanpa
accountId) tetap cocok dengan akun default; binding bercakupan akun tetap opsional. openclaw doctor --fixjuga memperbaiki bentuk campuran dengan memindahkan nilai akun tunggal tingkat atas bercakupan akun ke akun yang dipromosikan dan dipilih untuk saluran tersebut. Sebagian besar saluran menggunakanaccounts.default; Matrix dapat mempertahankan target bernama/default yang cocok yang sudah ada.
Saluran Plugin lainnya
Banyak saluran Plugin dikonfigurasi sebagaichannels.<id> dan didokumentasikan di halaman saluran khususnya (misalnya Feishu, Matrix, LINE, Nostr, Zalo, Nextcloud Talk, Synology Chat, dan Twitch).
Lihat indeks saluran lengkap: Saluran.
Gerbang mention chat grup
Pesan grup default ke wajib mention (mention metadata atau pola regex aman). Berlaku untuk chat grup WhatsApp, Telegram, Discord, Google Chat, dan iMessage. Balasan terlihat dikendalikan secara terpisah. Ruang grup/channel secara default menggunakanmessages.groupChat.visibleReplies: "message_tool": OpenClaw tetap memproses giliran, tetapi balasan akhir normal tetap privat dan keluaran ruang yang terlihat memerlukan message(action=send). Atur "automatic" hanya saat Anda menginginkan perilaku lama, yaitu balasan normal diposting kembali ke ruang. Untuk menerapkan perilaku balasan terlihat khusus alat yang sama ke chat langsung juga, atur messages.visibleReplies: "message_tool"; harness Codex juga menggunakan perilaku khusus alat itu sebagai default chat langsung yang tidak disetel.
Balasan terlihat khusus alat memerlukan model/runtime yang andal memanggil alat. Jika
log sesi menampilkan teks asisten dengan didSendViaMessagingTool: false, berarti
model menghasilkan jawaban akhir privat alih-alih memanggil alat pesan.
Beralihlah ke model pemanggil alat yang lebih kuat untuk channel tersebut, atau atur
messages.groupChat.visibleReplies: "automatic" untuk memulihkan balasan akhir terlihat
lama.
Jika alat pesan tidak tersedia di bawah kebijakan alat aktif, OpenClaw kembali ke balasan terlihat otomatis alih-alih menekan respons secara diam-diam. openclaw doctor memperingatkan ketidakcocokan ini.
Gateway memuat ulang panas konfigurasi messages setelah file disimpan. Mulai ulang hanya saat pemantauan file atau pemuatan ulang konfigurasi dinonaktifkan dalam deployment.
Jenis mention:
- Mention metadata: @-mention platform native. Diabaikan dalam mode self-chat WhatsApp.
- Pola teks: Pola regex aman di
agents.list[].groupChat.mentionPatterns. Pola tidak valid dan pengulangan bersarang yang tidak aman diabaikan. - Pembatasan mention diterapkan hanya saat deteksi memungkinkan (mention native atau setidaknya satu pola).
messages.groupChat.historyLimit menetapkan default global. Channel dapat menimpa dengan channels.<channel>.historyLimit (atau per akun). Atur 0 untuk menonaktifkan.
messages.visibleReplies adalah default giliran sumber global; messages.groupChat.visibleReplies menimpanya untuk giliran sumber grup/channel. Saat messages.visibleReplies tidak disetel, harness dapat menyediakan default langsung/sumbernya sendiri; harness Codex default ke message_tool. Allowlist channel dan pembatasan mention tetap menentukan apakah suatu giliran diproses.
Batas riwayat DM
telegram, whatsapp, discord, slack, signal, imessage, msteams.
Mode self-chat
Sertakan nomor Anda sendiri diallowFrom untuk mengaktifkan mode self-chat (mengabaikan @-mention native, hanya merespons pola teks):
Perintah (penanganan perintah chat)
Detail perintah
Detail perintah
- Blok ini mengonfigurasi permukaan perintah. Untuk katalog perintah bawaan + paket saat ini, lihat Slash Commands.
- Halaman ini adalah referensi kunci konfigurasi, bukan katalog perintah lengkap. Perintah milik channel/plugin seperti QQ Bot
/bot-ping/bot-help/bot-logs, LINE/card, device-pair/pair, memory/dreaming, phone-control/phone, dan Talk/voicedidokumentasikan di halaman channel/plugin masing-masing ditambah Slash Commands. - Perintah teks harus berupa pesan mandiri dengan awalan
/. native: "auto"mengaktifkan perintah native untuk Discord/Telegram, membiarkan Slack nonaktif.nativeSkills: "auto"mengaktifkan perintah skill native untuk Discord/Telegram, membiarkan Slack nonaktif.- Override per channel:
channels.discord.commands.native(bool atau"auto"). Untuk Discord,falsemelewati pendaftaran perintah native dan pembersihan saat startup. - Override pendaftaran skill native per channel dengan
channels.<provider>.commands.nativeSkills. channels.telegram.customCommandsmenambahkan entri menu bot Telegram tambahan.bash: truemengaktifkan! <cmd>untuk shell host. Memerlukantools.elevated.enableddan pengirim ditools.elevated.allowFrom.<channel>.config: truemengaktifkan/config(membaca/menulisopenclaw.json). Untuk klien Gatewaychat.send, penulisan persisten/config set|unsetjuga memerlukanoperator.admin;/config showbaca-saja tetap tersedia untuk klien operator berscope tulis normal.mcp: truemengaktifkan/mcpuntuk konfigurasi server MCP yang dikelola OpenClaw di bawahmcp.servers.plugins: truemengaktifkan/pluginsuntuk penemuan Plugin, instalasi, serta kontrol aktif/nonaktif.channels.<provider>.configWritesmembatasi mutasi konfigurasi per channel (default: true).- Untuk channel multi-akun,
channels.<provider>.accounts.<id>.configWritesjuga membatasi penulisan yang menargetkan akun tersebut (misalnya/allowlist --config --account <id>atau/config set channels.<provider>.accounts.<id>...). restart: falsemenonaktifkan tindakan/restartdan alat restart Gateway. Default:true.ownerAllowFromadalah allowlist pemilik eksplisit untuk perintah/alat khusus pemilik. Ini terpisah dariallowFrom.ownerDisplay: "hash"melakukan hash id pemilik dalam prompt sistem. AturownerDisplaySecretuntuk mengontrol hashing.allowFrombersifat per penyedia. Saat disetel, ini adalah satu-satunya sumber otorisasi (allowlist/pairing channel danuseAccessGroupsdiabaikan).useAccessGroups: falsememungkinkan perintah melewati kebijakan grup akses saatallowFromtidak disetel.- Peta dokumentasi perintah:
Terkait
- Referensi konfigurasi — kunci tingkat atas
- Konfigurasi — agents
- Ikhtisar channel