CLI commands
Mesaj
openclaw message
İleti ve kanal eylemleri göndermek için tek giden komut (Discord/Google Chat/iMessage/Matrix/Mattermost (Plugin)/Microsoft Teams/Signal/Slack/Telegram/WhatsApp).
Kullanım
openclaw message <subcommand> [flags]
Kanal seçimi:
- Birden fazla kanal yapılandırıldıysa
--channelzorunludur. - Tam olarak bir kanal yapılandırıldıysa varsayılan olur.
- Değerler:
discord|googlechat|imessage|matrix|mattermost|msteams|signal|slack|telegram|whatsapp(Mattermost Plugin gerektirir) openclaw message,--channelveya kanal önekli bir hedef bulunduğunda seçilen kanalı sahibi olan Plugin ile çözümler; aksi halde varsayılan kanal çıkarımı için yapılandırılmış kanal Pluginlerini yükler.
Hedef biçimleri (--target):
- WhatsApp: E.164, grup JID'si veya WhatsApp Channel/Newsletter JID'si (
...@newsletter) - Telegram: sohbet kimliği,
@usernameveya forum konusu hedefi (-1001234567890:topic:42ya da--thread-id 42) - Discord:
channel:<id>veyauser:<id>(ya da<@id>mention; ham sayısal kimlikler kanal olarak değerlendirilir) - Google Chat:
spaces/<spaceId>veyausers/<userId> - Slack:
channel:<id>veyauser:<id>(ham kanal kimliği kabul edilir) - Mattermost (Plugin):
channel:<id>,user:<id>veya@username(çıplak kimlikler kanal olarak değerlendirilir) - Signal:
+E.164,group:<id>,signal:+E.164,signal:group:<id>veyausername:<name>/u:<name> - iMessage: handle,
chat_id:<id>,chat_guid:<guid>veyachat_identifier:<id> - Matrix:
@user:server,!room:serverveya#alias:server - Microsoft Teams: konuşma kimliği (
19:[email protected]) veyaconversation:<id>ya dauser:<aad-object-id>
Ad arama:
- Desteklenen sağlayıcılar için (Discord/Slack/vb.),
Helpveya#helpgibi kanal adları dizin önbelleği üzerinden çözümlenir. - Önbellek isabetsizliğinde, sağlayıcı destekliyorsa OpenClaw canlı dizin araması deneyecektir.
Yaygın bayraklar
--channel <name>--account <id>--target <dest>(send/poll/read/vb. için hedef kanal veya kullanıcı)--targets <name>(tekrar edilebilir; yalnızca broadcast)--json--dry-run--verbose
SecretRef davranışı
openclaw message, seçilen eylemi çalıştırmadan önce desteklenen kanal SecretRef'lerini çözümler.- Çözümleme mümkün olduğunda etkin eylem hedefine kapsamlanır:
--channelayarlandığında kanal kapsamlı (veyadiscord:...gibi önekli hedeflerden çıkarıldığında)--accountayarlandığında hesap kapsamlı (kanal genelleri + seçilen hesap yüzeyleri)--accountatlandığında OpenClaw birdefaulthesap SecretRef kapsamını zorlamaz
- İlgisiz kanallardaki çözümlenmemiş SecretRef'ler hedeflenmiş bir ileti eylemini engellemez.
- Seçilen kanal/hesap SecretRef'i çözümlenmemişse komut bu eylem için kapalı başarısız olur.
Eylemler
Çekirdek
-
send- Kanallar: WhatsApp/Telegram/Discord/Google Chat/Slack/Mattermost (Plugin)/Signal/iMessage/Matrix/Microsoft Teams
- Gerekli:
--targetve ayrıca--message,--mediaveya--presentation - İsteğe bağlı:
--media,--presentation,--delivery,--pin,--reply-to,--thread-id,--gif-playback,--force-document,--silent - Paylaşılan sunum yükleri:
--presentation, çekirdeğin seçilen kanalın bildirdiği yetenekler üzerinden işlediği semantik bloklar (text,context,divider,buttons,select) gönderir. Bkz. İleti Sunumu. - Genel teslim tercihleri:
--delivery,{ "pin": true }gibi teslim ipuçlarını kabul eder; kanal destekliyorsa--pinsabitlenmiş teslim için kısaltmadır. - Yalnızca Telegram:
--force-document(Telegram sıkıştırmasını önlemek için görselleri ve GIF'leri belge olarak gönderir) - Yalnızca Telegram:
--thread-id(forum konusu kimliği) - Yalnızca Slack:
--thread-id(iş parçacığı zaman damgası;--reply-toaynı alanı kullanır) - Telegram + Discord:
--silent - Yalnızca WhatsApp:
--gif-playback; WhatsApp Channels/Newsletters yerel@newsletterJID'leriyle adreslenir.
-
poll- Kanallar: WhatsApp/Telegram/Discord/Matrix/Microsoft Teams
- Gerekli:
--target,--poll-question,--poll-option(tekrar edilebilir) - İsteğe bağlı:
--poll-multi - Yalnızca Discord:
--poll-duration-hours,--silent,--message - Yalnızca Telegram:
--poll-duration-seconds(5-600),--silent,--poll-anonymous/--poll-public,--thread-id
-
react- Kanallar: Discord/Google Chat/Slack/Telegram/WhatsApp/Signal/Matrix
- Gerekli:
--message-id,--target - İsteğe bağlı:
--emoji,--remove,--participant,--from-me,--target-author,--target-author-uuid - Not:
--remove,--emojigerektirir (desteklenen yerlerde kendi tepkilerinizi temizlemek için--emojiatlayın; bkz. /tools/reactions) - Yalnızca WhatsApp:
--participant,--from-me - Signal grup tepkileri:
--target-authorveya--target-author-uuidgerekli
-
reactions- Kanallar: Discord/Google Chat/Slack/Matrix
- Gerekli:
--message-id,--target - İsteğe bağlı:
--limit
-
read- Kanallar: Discord/Slack/Matrix
- Gerekli:
--target - İsteğe bağlı:
--limit,--message-id,--before,--after - Yalnızca Slack:
--message-idbelirli bir Slack ileti zaman damgasını okur; kesin bir iş parçacığı yanıtını okumak için--thread-idile birleştirin. - Yalnızca Discord:
--around
-
edit- Kanallar: Discord/Slack/Matrix
- Gerekli:
--message-id,--message,--target
-
delete- Kanallar: Discord/Slack/Telegram/Matrix
- Gerekli:
--message-id,--target
-
pin/unpin- Kanallar: Discord/Slack/Matrix
- Gerekli:
--message-id,--target
-
pins(liste)- Kanallar: Discord/Slack/Matrix
- Gerekli:
--target
-
permissions- Kanallar: Discord/Matrix
- Gerekli:
--target - Yalnızca Matrix: Matrix şifrelemesi etkinleştirildiğinde ve doğrulama eylemlerine izin verildiğinde kullanılabilir
-
search- Kanallar: Discord
- Gerekli:
--guild-id,--query - İsteğe bağlı:
--channel-id,--channel-ids(tekrar edilebilir),--author-id,--author-ids(tekrar edilebilir),--limit
İş Parçacıkları
-
thread create- Kanallar: Discord
- Gerekli:
--thread-name,--target(kanal kimliği) - İsteğe bağlı:
--message-id,--message,--auto-archive-min
-
thread list- Kanallar: Discord
- Gerekli:
--guild-id - İsteğe bağlı:
--channel-id,--include-archived,--before,--limit
-
thread reply- Kanallar: Discord
- Gerekli:
--target(iş parçacığı kimliği),--message - İsteğe bağlı:
--media,--reply-to
Emojiler
-
emoji list- Discord:
--guild-id - Slack: ek bayrak yok
- Discord:
-
emoji upload- Kanallar: Discord
- Gerekli:
--guild-id,--emoji-name,--media - İsteğe bağlı:
--role-ids(tekrar edilebilir)
Çıkartmalar
-
sticker send- Kanallar: Discord
- Gerekli:
--target,--sticker-id(tekrar edilebilir) - İsteğe bağlı:
--message
-
sticker upload- Kanallar: Discord
- Gerekli:
--guild-id,--sticker-name,--sticker-desc,--sticker-tags,--media
Roller / Kanallar / Üyeler / Ses
role info(Discord):--guild-idrole add/role remove(Discord):--guild-id,--user-id,--role-idchannel info(Discord):--targetchannel list(Discord):--guild-idmember info(Discord/Slack):--user-id(Discord için +--guild-id)voice status(Discord):--guild-id,--user-id
Etkinlikler
event list(Discord):--guild-idevent create(Discord):--guild-id,--event-name,--start-time- İsteğe bağlı:
--end-time,--desc,--channel-id,--location,--event-type
- İsteğe bağlı:
Moderasyon (Discord)
timeout:--guild-id,--user-id(isteğe bağlı--duration-minveya--until; zaman aşımını temizlemek için ikisini de atlayın)kick:--guild-id,--user-id(+--reason)ban:--guild-id,--user-id(+--delete-days,--reason)timeoutayrıca--reasondestekler
Broadcast
broadcast- Kanallar: yapılandırılmış herhangi bir kanal; tüm sağlayıcıları hedeflemek için
--channel allkullanın - Gerekli:
--targets <target...> - İsteğe bağlı:
--message,--media,--dry-run
- Kanallar: yapılandırılmış herhangi bir kanal; tüm sağlayıcıları hedeflemek için
Örnekler
Discord yanıtı gönderin:
openclaw message send --channel discord \
--target channel:123 --message "hi" --reply-to 456
Semantik düğmelerle bir ileti gönderin:
openclaw message send --channel discord \
--target channel:123 --message "Choose:" \
--presentation '{"blocks":[{"type":"buttons","buttons":[{"label":"Approve","value":"approve","style":"success"},{"label":"Decline","value":"decline","style":"danger"}]}]}'
Çekirdek, kanal yeteneğine bağlı olarak aynı presentation yükünü Discord bileşenlerine, Slack bloklarına, Telegram satır içi düğmelerine, Mattermost props öğelerine veya Teams/Feishu kartlarına işler. Tam sözleşme ve geri dönüş kuralları için bkz. İleti Sunumu.
Daha zengin bir sunum yükü gönderin:
openclaw message send --channel googlechat --target spaces/AAA... \
--message "Choose:" \
--presentation '{"title":"Deploy approval","tone":"warning","blocks":[{"type":"text","text":"Choose a path"},{"type":"buttons","buttons":[{"label":"Approve","value":"approve"},{"label":"Decline","value":"decline"}]}]}'
Discord anketi oluşturun:
openclaw message poll --channel discord \
--target channel:123 \
--poll-question "Snack?" \
--poll-option Pizza --poll-option Sushi \
--poll-multi --poll-duration-hours 48
Telegram anketi oluşturun (2 dakika içinde otomatik kapanır):
openclaw message poll --channel telegram \
--target @mychat \
--poll-question "Lunch?" \
--poll-option Pizza --poll-option Sushi \
--poll-duration-seconds 120 --silent
Teams proaktif iletisi gönderin:
openclaw message send --channel msteams \
--target conversation:19:[email protected] --message "hi"
Teams anketi oluşturun:
openclaw message poll --channel msteams \
--target conversation:19:[email protected] \
--poll-question "Lunch?" \
--poll-option Pizza --poll-option Sushi
Slack'te tepki verin:
openclaw message react --channel slack \
--target C123 --message-id 456 --emoji "✅"
Bir Signal grubunda tepki verin:
openclaw message react --channel signal \
--target signal:group:abc123 --message-id 1737630212345 \
--emoji "✅" --target-author-uuid 123e4567-e89b-12d3-a456-426614174000
Genel sunum üzerinden Telegram satır içi düğmeleri gönderin:
openclaw message send --channel telegram --target @mychat --message "Choose:" \
--presentation '{"blocks":[{"type":"buttons","buttons":[{"label":"Yes","value":"cmd:yes"},{"label":"No","value":"cmd:no"}]}]}'
Genel sunum üzerinden Teams kartı gönderin:
openclaw message send --channel msteams \
--target conversation:19:[email protected] \
--presentation '{"title":"Status update","blocks":[{"type":"text","text":"Build completed"}]}'
Sıkıştırmayı önlemek için Telegram görselini belge olarak gönderin:
openclaw message send --channel telegram --target @mychat \
--media ./diagram.png --force-document