openclaw message
Comando único de salida para enviar mensajes y acciones de canal (Discord/Google Chat/Slack/Mattermost (plugin)/Telegram/WhatsApp/Signal/iMessage/MS Teams).
Uso
openclaw message <subcommand> [flags]
Selección de canal:
--channeles obligatorio si hay más de un canal configurado.- Si solo hay un canal configurado, se usa como predeterminado.
- Valores:
whatsapp|telegram|discord|googlechat|slack|mattermost|signal|imessage|msteams(Mattermost requiere plugin)
Formatos de destino (--target):
- WhatsApp: E.164 o JID de grupo
- Telegram: chat id o
@username - Discord:
channel:<id>ouser:<id>(o mención<@id>; los ids numéricos sin prefijo se tratan como canales) - Google Chat:
spaces/<spaceId>ousers/<userId> - Slack:
channel:<id>ouser:<id>(se acepta id de canal sin prefijo) - Mattermost (plugin):
channel:<id>,user:<id>, o@username(los ids sin prefijo se tratan como canales) - Signal:
+E.164,group:<id>,signal:+E.164,signal:group:<id>, ousername:<name>/u:<name> - iMessage: handle,
chat_id:<id>,chat_guid:<guid>, ochat_identifier:<id> - MS Teams: id de conversación (
19:[email protected]) oconversation:<id>ouser:<aad-object-id>
Búsqueda por nombre:
- Para proveedores compatibles (Discord/Slack/etc), nombres de canal como
Helpo#helpse resuelven mediante la caché de directorio. - Si no hay coincidencia en la caché, OpenClaw intenta una búsqueda en vivo cuando el proveedor lo soporta.
Flags comunes
--channel <name>--account <id>--target <dest>(canal o usuario de destino para send/poll/read/etc)--targets <name>(repetible; solo broadcast)--json--dry-run--verbose
Acciones
Principales
-
send- Canales: WhatsApp/Telegram/Discord/Google Chat/Slack/Mattermost (plugin)/Signal/iMessage/MS Teams
- Obligatorio:
--target, más--messageo--media - Opcional:
--media,--reply-to,--thread-id,--gif-playback - Solo Telegram:
--buttons(requierechannels.telegram.capabilities.inlineButtonspara permitirlo) - Solo Telegram:
--thread-id(id de tema del foro) - Solo Slack:
--thread-id(timestamp del hilo;--reply-tousa el mismo campo) - Solo WhatsApp:
--gif-playback
-
poll- Canales: WhatsApp/Telegram/Discord/Matrix/MS Teams
- Obligatorio:
--target,--poll-question,--poll-option(repetible) - Opcional:
--poll-multi - Solo Discord:
--poll-duration-hours,--silent,--message - Solo Telegram:
--poll-duration-seconds(5-600),--silent,--poll-anonymous/--poll-public,--thread-id
-
react- Canales: Discord/Google Chat/Slack/Telegram/WhatsApp/Signal
- Obligatorio:
--message-id,--target - Opcional:
--emoji,--remove,--participant,--from-me,--target-author,--target-author-uuid - Nota:
--removerequiere--emoji(omite--emojipara eliminar reacciones propias donde sea compatible; consulta /tools/reactions) - Solo WhatsApp:
--participant,--from-me - Reacciones en grupos de Signal: se requiere
--target-authoro--target-author-uuid
-
reactions- Canales: Discord/Google Chat/Slack
- Obligatorio:
--message-id,--target - Opcional:
--limit
-
read- Canales: Discord/Slack
- Obligatorio:
--target - Opcional:
--limit,--before,--after - Solo Discord:
--around
-
edit- Canales: Discord/Slack
- Obligatorio:
--message-id,--message,--target
-
delete- Canales: Discord/Slack/Telegram
- Obligatorio:
--message-id,--target
-
pin/unpin- Canales: Discord/Slack
- Obligatorio:
--message-id,--target
-
pins(listar)- Canales: Discord/Slack
- Obligatorio:
--target
-
permissions- Canales: Discord
- Obligatorio:
--target
-
search- Canales: Discord
- Obligatorio:
--guild-id,--query - Opcional:
--channel-id,--channel-ids(repetible),--author-id,--author-ids(repetible),--limit
Hilos
-
thread create- Canales: Discord
- Obligatorio:
--thread-name,--target(id de canal) - Opcional:
--message-id,--message,--auto-archive-min
-
thread list- Canales: Discord
- Obligatorio:
--guild-id - Opcional:
--channel-id,--include-archived,--before,--limit
-
thread reply- Canales: Discord
- Obligatorio:
--target(id de hilo),--message - Opcional:
--media,--reply-to
Emojis
-
emoji list- Discord:
--guild-id - Slack: sin flags adicionales
- Discord:
-
emoji upload- Canales: Discord
- Obligatorio:
--guild-id,--emoji-name,--media - Opcional:
--role-ids(repetible)
Stickers
-
sticker send- Canales: Discord
- Obligatorio:
--target,--sticker-id(repetible) - Opcional:
--message
-
sticker upload- Canales: Discord
- Obligatorio:
--guild-id,--sticker-name,--sticker-desc,--sticker-tags,--media
Roles / Canales / Miembros / Voz
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(+--guild-idpara Discord)voice status(Discord):--guild-id,--user-id
Eventos
event list(Discord):--guild-idevent create(Discord):--guild-id,--event-name,--start-time- Opcional:
--end-time,--desc,--channel-id,--location,--event-type
- Opcional:
Moderación (Discord)
timeout:--guild-id,--user-id(opcional--duration-mino--until; omite ambos para eliminar el timeout)kick:--guild-id,--user-id(+--reason)ban:--guild-id,--user-id(+--delete-days,--reason)timeouttambién soporta--reason
Difusión
broadcast- Canales: cualquier canal configurado; usa
--channel allpara enviar a todos los proveedores - Obligatorio:
--targets(repetible) - Opcional:
--message,--media,--dry-run
- Canales: cualquier canal configurado; usa
Ejemplos
Enviar una respuesta en Discord:
openclaw message send --channel discord \
--target channel:123 --message "hi" --reply-to 456
Enviar un mensaje de Discord con componentes:
openclaw message send --channel discord \
--target channel:123 --message "Choose:" \
--components '{"text":"Choose a path","blocks":[{"type":"actions","buttons":[{"label":"Approve","style":"success"},{"label":"Decline","style":"danger"}]}]}'
Consulta Discord components para ver el esquema completo.
Crear una encuesta en Discord:
openclaw message poll --channel discord \
--target channel:123 \
--poll-question "Snack?" \
--poll-option Pizza --poll-option Sushi \
--poll-multi --poll-duration-hours 48
Crear una encuesta en Telegram (cierre automático en 2 minutos):
openclaw message poll --channel telegram \
--target @mychat \
--poll-question "Lunch?" \
--poll-option Pizza --poll-option Sushi \
--poll-duration-seconds 120 --silent
Enviar un mensaje proactivo en Teams:
openclaw message send --channel msteams \
--target conversation:19:[email protected] --message "hi"
Crear una encuesta en Teams:
openclaw message poll --channel msteams \
--target conversation:19:[email protected] \
--poll-question "Lunch?" \
--poll-option Pizza --poll-option Sushi
Reaccionar en Slack:
openclaw message react --channel slack \
--target C123 --message-id 456 --emoji "✅"
Reaccionar en un grupo de Signal:
openclaw message react --channel signal \
--target signal:group:abc123 --message-id 1737630212345 \
--emoji "✅" --target-author-uuid 123e4567-e89b-12d3-a456-426614174000
Enviar botones inline en Telegram:
openclaw message send --channel telegram --target @mychat --message "Choose:" \
--buttons '[ [{"text":"Yes","callback_data":"cmd:yes"}], [{"text":"No","callback_data":"cmd:no"}] ]'