message
openclaw message
Sección titulada «openclaw message»Comando único de salida para enviar mensajes y acciones de canal (Discord/Google Chat/iMessage/Matrix/Mattermost (plugin)/Microsoft Teams/Signal/Slack/Telegram/WhatsApp).
openclaw message <subcommand> [flags]Selección de canal:
--channelobligatorio si hay más de un canal configurado.- Si exactamente un canal está configurado, se convierte en el predeterminado.
- Valores:
discord|googlechat|imessage|matrix|mattermost|msteams|signal|slack|telegram|whatsapp(Mattermost requiere el complemento)
Formatos de destino (--target):
- WhatsApp: E.164 o JID de grupo
- Telegram: id de chat o
@username - Discord:
channel:<id>ouser:<id>(o mención de<@id>; los ids numéricos sin procesar se tratan como canales) - Google Chat:
spaces/<spaceId>ousers/<userId> - Slack:
channel:<id>ouser:<id>(se acepta el id de canal sin procesar) - Mattermost (plugin):
channel:<id>,user:<id>, o@username(los ids simples se tratan como canales) - Signal:
+E.164,group:<id>,signal:+E.164,signal:group:<id>, ousername:<name>/u:<name> - iMessage: identificador,
chat_id:<id>,chat_guid:<guid>, ochat_identifier:<id> - Matrix:
@user:server,!room:servero#alias:server - Microsoft Teams: id de conversación (
19:[email protected]) oconversation:<id>ouser:<aad-object-id>
Búsqueda por nombre:
- Para proveedores compatibles (Discord/Slack/etc), los nombres de canal como
Helpo#helpse resuelven mediante la caché del directorio. - Si no se encuentra en la caché, OpenClaw intentará realizar una búsqueda en vivo en el directorio cuando el proveedor lo admita.
Opciones comunes
Sección titulada «Opciones comunes»--channel <name>--account <id>--target <dest>(canal o usuario de destino para enviar/encuesta/lectura/etc)--targets <name>(repetir; solo transmisión)--json--dry-run--verbose
Comportamiento de SecretRef
Sección titulada «Comportamiento de SecretRef»openclaw messageresuelve los SecretRefs de canal admitidos antes de ejecutar la acción seleccionada.- La resolución se limita al objetivo de la acción activa cuando es posible:
- con alcance de canal cuando se establece
--channel(o se infiere de objetivos con prefijo comodiscord:...) - con alcance de cuenta cuando se establece
--account(globales del canal + superficies de la cuenta seleccionada) - cuando se omite
--account, OpenClaw no fuerza un alcance de SecretRef de cuentadefault
- con alcance de canal cuando se establece
- Los SecretRefs no resueltos en canales no relacionados no bloquean una acción de mensaje dirigida.
- Si el SecretRef del canal/cuenta seleccionado no está resuelto, el comando falla de forma segura para esa acción.
Acciones
Sección titulada «Acciones»Principal
Sección titulada «Principal»-
send- Canales: WhatsApp/Telegram/Discord/Google Chat/Slack/Mattermost (plugin)/Signal/iMessage/Matrix/Microsoft Teams
- Obligatorio:
--target, más--messageo--media - Opcional:
--media,--reply-to,--thread-id,--gif-playback - Solo para Telegram:
--buttons(requierechannels.telegram.capabilities.inlineButtonspara permitirlo) - Solo para Telegram:
--force-document(envía imágenes y GIFs como documentos para evitar la compresión de Telegram) - Solo para Telegram:
--thread-id(id del tema del foro) - Solo para Slack:
--thread-id(marca de tiempo del hilo;--reply-tousa el mismo campo) - Solo para WhatsApp:
--gif-playback
-
poll- Canales: WhatsApp/Telegram/Discord/Matrix/Microsoft Teams
- Obligatorio:
--target,--poll-question,--poll-option(repetir) - Opcional:
--poll-multi - Solo para Discord:
--poll-duration-hours,--silent,--message - Solo para Telegram:
--poll-duration-seconds(5-600),--silent,--poll-anonymous/--poll-public,--thread-id
-
react- Canales: Discord/Google Chat/Slack/Telegram/WhatsApp/Signal/Matrix
- Obligatorio:
--message-id,--target - Opcional:
--emoji,--remove,--participant,--from-me,--target-author,--target-author-uuid - Nota:
--removerequiere--emoji(omite--emojipara limpiar las propias reacciones donde sea compatible; consulta /tools/reactions) - Solo para WhatsApp:
--participant,--from-me - Reacciones de grupo de Signal: se requiere
--target-authoro--target-author-uuid
-
reactions- Canales: Discord/Google Chat/Slack/Matrix
- Obligatorio:
--message-id,--target - Opcional:
--limit
-
read- Canales: Discord/Slack/Matrix
- Obligatorio:
--target - Opcional:
--limit,--before,--after - Solo Discord:
--around
-
edit- Canales: Discord/Slack/Matrix
- Obligatorio:
--message-id,--message,--target
-
delete- Canales: Discord/Slack/Telegram/Matrix
- Obligatorio:
--message-id,--target
-
pin/unpin- Canales: Discord/Slack/Matrix
- Obligatorio:
--message-id,--target
-
pins(lista)- Canales: Discord/Slack/Matrix
- Obligatorio:
--target
-
permissions- Canales: Discord/Matrix
- Obligatorio:
--target - Solo Matrix: disponible cuando el cifrado de Matrix está habilitado y se permiten las acciones de verificación
-
search- Canales: Discord
- Obligatorio:
--guild-id,--query - Opcional:
--channel-id,--channel-ids(repetir),--author-id,--author-ids(repetir),--limit
-
thread create- Canales: Discord
- Obligatorio:
--thread-name,--target(id del 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 del hilo),--message - Opcional:
--media,--reply-to
-
emoji list- Discord:
--guild-id - Slack: sin banderas adicionales
- Discord:
-
emoji upload- Canales: Discord
- Obligatorio:
--guild-id,--emoji-name,--media - Opcional:
--role-ids(repetir)
Pegatinas
Sección titulada «Pegatinas»-
sticker send- Canales: Discord
- Obligatorio:
--target,--sticker-id(repetir) - Opcional:
--message
-
sticker upload- Canales: Discord
- Obligatorio:
--guild-id,--sticker-name,--sticker-desc,--sticker-tags,--media
Roles / Canales / Miembros / Voz
Sección titulada «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
Sección titulada «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)
Sección titulada «Moderación (Discord)»timeout:--guild-id,--user-id(opcional--duration-mino--until; omita ambos para eliminar el tiempo de espera)kick:--guild-id,--user-id(+--reason)ban:--guild-id,--user-id(+--delete-days,--reason)timeouttambién admite--reason
Transmisión
Sección titulada «Transmisión»broadcast- Canales: cualquier canal configurado; use
--channel allpara apuntar a todos los proveedores - Obligatorio:
--targets(repetir) - Opcional:
--message,--media,--dry-run
- Canales: cualquier canal configurado; use
Ejemplos
Sección titulada «Ejemplos»Enviar una respuesta de Discord:
openclaw message send --channel discord \ --target channel:123 --message "hi" --reply-to 456Enviar 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"}]}]}'Consulte Componentes de Discord para ver el esquema completo.
Crear una encuesta de Discord:
openclaw message poll --channel discord \ --target channel:123 \ --poll-question "Snack?" \ --poll-option Pizza --poll-option Sushi \ --poll-multi --poll-duration-hours 48Crear una encuesta de 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 --silentEnviar un mensaje proactivo de Teams:
openclaw message send --channel msteams \ --target conversation:19:[email protected] --message "hi"Crear una encuesta de Teams:
openclaw message poll --channel msteams \ --target conversation:19:[email protected] \ --poll-question "Lunch?" \ --poll-option Pizza --poll-option SushiReaccionar 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-426614174000Enviar botones en línea de Telegram:
openclaw message send --channel telegram --target @mychat --message "Choose:" \ --buttons '[ [{"text":"Yes","callback_data":"cmd:yes"}], [{"text":"No","callback_data":"cmd:no"}] ]'Enviar una imagen de Telegram como documento para evitar la compresión:
openclaw message send --channel telegram --target @mychat \ --media ./diagram.png --force-document