Claves de configuración por canal bajoDocumentation 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.*. Cubre el acceso por MD y grupos,
las configuraciones multicuenta, el control por menciones y las claves por canal para Slack, Discord,
Telegram, WhatsApp, Matrix, iMessage y los demás plugins de canal incluidos.
Para agentes, herramientas, el runtime del gateway y otras claves de nivel superior, consulta
Referencia de configuración.
Canales
Cada canal se inicia automáticamente cuando existe su sección de configuración, salvo que tengaenabled: false.
Acceso por MD y grupos
Todos los canales admiten políticas de MD y políticas de grupo:| Política de MD | Comportamiento |
|---|---|
pairing (predeterminada) | Los remitentes desconocidos reciben un código de emparejamiento de un solo uso; el propietario debe aprobarlo |
allowlist | Solo remitentes en allowFrom o en el almacén de permitidos emparejados |
open | Permite todos los MD entrantes; requiere allowFrom: ["*"] |
disabled | Ignora todos los MD entrantes |
| Política de grupo | Comportamiento |
|---|---|
allowlist (predeterminada) | Solo grupos que coinciden con la lista de permitidos configurada |
open | Omite las listas de permitidos de grupos; el control por menciones sigue aplicándose |
disabled | Bloquea todos los mensajes de grupos o salas |
channels.defaults.groupPolicy establece el valor predeterminado cuando groupPolicy de un proveedor no está definido.
Los códigos de emparejamiento caducan después de 1 hora. Las solicitudes pendientes de emparejamiento de MD están limitadas a 3 por canal.
Si falta por completo un bloque de proveedor (channels.<provider> ausente), la política de grupo en runtime vuelve a allowlist (cierre seguro) con una advertencia al iniciar.Sobrescrituras de modelo por canal
Usachannels.modelByChannel para fijar IDs de canal específicos a un modelo. Los valores aceptan provider/model o alias de modelo configurados. La asignación de canal se aplica cuando una sesión aún no tiene una sobrescritura de modelo, por ejemplo, establecida mediante /model.
Valores predeterminados de canal y Heartbeat
Usachannels.defaults para compartir el comportamiento de política de grupo y Heartbeat entre proveedores:
channels.defaults.groupPolicy: política de grupo de respaldo cuandogroupPolicya nivel de proveedor no está definida.channels.defaults.contextVisibility: modo predeterminado de visibilidad del contexto suplementario para todos los canales. Valores:all(predeterminado, incluye todo el contexto citado, de hilo e historial),allowlist(incluye solo contexto de remitentes en la lista de permitidos),allowlist_quote(igual que allowlist, pero conserva el contexto explícito de cita o respuesta). Sobrescritura por canal:channels.<channel>.contextVisibility.channels.defaults.heartbeat.showOk: incluye estados de canales correctos en la salida de Heartbeat.channels.defaults.heartbeat.showAlerts: incluye estados degradados o de error en la salida de Heartbeat.channels.defaults.heartbeat.useIndicator: representa una salida de Heartbeat compacta con estilo de indicador.
WhatsApp multicuenta
WhatsApp multicuenta
- Los comandos salientes usan de forma predeterminada la cuenta
defaultsi está presente; de lo contrario, el primer id de cuenta configurado, ordenado. channels.whatsapp.defaultAccountopcional sobrescribe esa selección de cuenta predeterminada de respaldo cuando coincide con un id de cuenta configurado.- El directorio de autenticación heredado de Baileys de una sola cuenta se migra mediante
openclaw doctorawhatsapp/default. - Sobrescrituras por cuenta:
channels.whatsapp.accounts.<id>.sendReadReceipts,channels.whatsapp.accounts.<id>.dmPolicy,channels.whatsapp.accounts.<id>.allowFrom.
Telegram
- Token del bot:
channels.telegram.botTokenochannels.telegram.tokenFile(solo archivo normal; se rechazan symlinks), conTELEGRAM_BOT_TOKENcomo respaldo para la cuenta predeterminada. apiRootes solo la raíz de la API de bots de Telegram. Usahttps://api.telegram.orgo tu raíz autoalojada/proxy, nohttps://api.telegram.org/bot<TOKEN>;openclaw doctor --fixelimina un sufijo final accidental/bot<TOKEN>.channels.telegram.defaultAccountopcional sobrescribe la selección de cuenta predeterminada cuando coincide con un id de cuenta configurado.- En configuraciones multicuenta (2 o más ids de cuenta), establece un valor predeterminado explícito (
channels.telegram.defaultAccountochannels.telegram.accounts.default) para evitar el enrutamiento de respaldo;openclaw doctoradvierte cuando falta o no es válido. configWrites: falsebloquea escrituras de configuración iniciadas desde Telegram (migraciones de ID de supergrupo,/config set|unset).- Las entradas de nivel superior
bindings[]contype: "acp"configuran vinculaciones ACP persistentes para temas de foro; usa el formato canónicochatId:topic:topicIdenmatch.peer.id. La semántica de los campos se comparte en Agentes ACP. - Las vistas previas de streaming de Telegram usan
sendMessage+editMessageTexty funcionan en chats directos y de grupo. - Política de reintentos: consulta Política de reintentos.
Discord
- Token:
channels.discord.token, conDISCORD_BOT_TOKENcomo reserva para la cuenta predeterminada. - Las llamadas salientes directas que proporcionan un
tokende Discord explícito usan ese token para la llamada; la configuración de reintentos/políticas de la cuenta sigue viniendo de la cuenta seleccionada en la instantánea activa del runtime. channels.discord.defaultAccountopcional anula la selección de la cuenta predeterminada cuando coincide con un id de cuenta configurado.- Usa
user:<id>(DM) ochannel:<id>(canal de guild) para los destinos de entrega; los ID numéricos sin prefijo se rechazan. - Los slugs de guild están en minúsculas con los espacios reemplazados por
-; las claves de canal usan el nombre convertido a slug (sin#). Prefiere los ID de guild. - Los mensajes creados por bots se ignoran de forma predeterminada.
allowBots: truelos habilita; usaallowBots: "mentions"para aceptar solo mensajes de bots que mencionen al bot (los mensajes propios siguen filtrándose). channels.discord.guilds.<id>.ignoreOtherMentions(y las anulaciones de canal) descarta mensajes que mencionan a otro usuario o rol pero no al bot (excluyendo @everyone/@here).channels.discord.mentionAliasesasigna texto@handlesaliente estable a ID de usuario de Discord antes de enviar, para que compañeros conocidos puedan mencionarse de forma determinista incluso cuando la caché transitoria del directorio está vacía. Las anulaciones por cuenta viven enchannels.discord.accounts.<accountId>.mentionAliases.maxLinesPerMessage(predeterminado 17) divide mensajes altos incluso cuando tienen menos de 2000 caracteres.channels.discord.threadBindingscontrola el enrutamiento vinculado a hilos de Discord:enabled: anulación de Discord para funciones de sesión vinculadas a hilos (/focus,/unfocus,/agents,/session idle,/session max-age, y entrega/enrutamiento vinculados)idleHours: anulación de Discord para el desenfoque automático por inactividad en horas (0lo deshabilita)maxAgeHours: anulación de Discord para la edad máxima estricta en horas (0lo deshabilita)spawnSessions: interruptor parasessions_spawn({ thread: true })y la creación/vinculación automática de hilos mediante ACP thread-spawn (predeterminado:true)defaultSpawnContext: contexto nativo de subagente para spawns vinculados a hilos ("fork"de forma predeterminada)
- Las entradas
bindings[]de nivel superior contype: "acp"configuran vinculaciones ACP persistentes para canales e hilos (usa el id de canal/hilo enmatch.peer.id). La semántica de los campos se comparte en Agentes ACP. channels.discord.ui.components.accentColorestablece el color de énfasis para contenedores de componentes v2 de Discord.channels.discord.voicehabilita conversaciones en canales de voz de Discord y anulaciones opcionales de unión automática + LLM + TTS. Las configuraciones de Discord solo de texto dejan la voz desactivada de forma predeterminada; establecechannels.discord.voice.enabled=truepara activarla.channels.discord.voice.modelanula opcionalmente el modelo LLM usado para las respuestas de canales de voz de Discord.channels.discord.voice.daveEncryptionychannels.discord.voice.decryptionFailureTolerancese pasan a las opciones DAVE de@discordjs/voice(truey24de forma predeterminada).channels.discord.voice.connectTimeoutMscontrola la espera inicial de Ready de@discordjs/voicepara/vc joine intentos de unión automática (30000de forma predeterminada).channels.discord.voice.reconnectGraceMscontrola cuánto tiempo puede tardar una sesión de voz desconectada en entrar en señalización de reconexión antes de que OpenClaw la destruya (15000de forma predeterminada).- La reproducción de voz de Discord no se interrumpe por el evento de inicio de habla de otro usuario. Para evitar bucles de retroalimentación, OpenClaw ignora la nueva captura de voz mientras se reproduce TTS.
- OpenClaw además intenta recuperar la recepción de voz saliendo y volviendo a unirse a una sesión de voz tras fallos repetidos de descifrado.
channels.discord.streaminges la clave canónica del modo de transmisión. Discord usa de forma predeterminadastreaming.mode: "progress"para que el progreso de herramientas/trabajo aparezca en un único mensaje de vista previa editado; establecestreaming.mode: "off"para deshabilitarlo. Los valores heredadosstreamModeystreamingbooleano siguen siendo alias de runtime; ejecutaopenclaw doctor --fixpara reescribir la configuración persistida.channels.discord.autoPresenceasigna la disponibilidad del runtime a la presencia del bot (healthy => online, degraded => idle, exhausted => dnd) y permite anulaciones opcionales de texto de estado.channels.discord.dangerouslyAllowNameMatchingvuelve a habilitar la coincidencia mutable de nombre/etiqueta (modo de compatibilidad de emergencia).channels.discord.execApprovals: entrega de aprobaciones de exec nativa de Discord y autorización de aprobadores.enabled:true,falseo"auto"(predeterminado). En modo automático, las aprobaciones de exec se activan cuando los aprobadores pueden resolverse desdeapproversocommands.ownerAllowFrom.approvers: ID de usuario de Discord autorizados para aprobar solicitudes de exec. Recurre acommands.ownerAllowFromcuando se omite.agentFilter: allowlist opcional de ID de agente. Omítelo para reenviar aprobaciones para todos los agentes.sessionFilter: patrones opcionales de clave de sesión (subcadena o regex).target: dónde enviar las solicitudes de aprobación."dm"(predeterminado) envía a los DM de los aprobadores,"channel"envía al canal de origen,"both"envía a ambos. Cuando el destino incluye"channel", los botones solo pueden usarlos los aprobadores resueltos.cleanupAfterResolve: cuando estrue, elimina los DM de aprobación tras aprobación, denegación o timeout.
off (ninguna), own (mensajes del bot, predeterminado), all (todos los mensajes), allowlist (desde guilds.<id>.users en todos los mensajes).
Google Chat
- JSON de cuenta de servicio: en línea (
serviceAccount) o basado en archivo (serviceAccountFile). - También se admite SecretRef de cuenta de servicio (
serviceAccountRef). - Reservas de env:
GOOGLE_CHAT_SERVICE_ACCOUNToGOOGLE_CHAT_SERVICE_ACCOUNT_FILE. - Usa
spaces/<spaceId>ousers/<userId>para los destinos de entrega. channels.googlechat.dangerouslyAllowNameMatchingvuelve a habilitar la coincidencia mutable de principales de correo electrónico (modo de compatibilidad de emergencia).
Slack
- Modo Socket requiere tanto
botTokencomoappToken(SLACK_BOT_TOKEN+SLACK_APP_TOKENpara la reserva de env de la cuenta predeterminada). - Modo HTTP requiere
botTokenmássigningSecret(en la raíz o por cuenta). socketModepasa los ajustes de transporte del modo Socket del SDK de Slack a la API pública del receptor Bolt. Úsalo solo al investigar timeout de ping/pong o comportamiento de websocket obsoleto.botToken,appToken,signingSecretyuserTokenaceptan cadenas de texto sin formato u objetos SecretRef.- Las instantáneas de cuenta de Slack exponen campos de origen/estado por credencial como
botTokenSource,botTokenStatus,appTokenStatusy, en modo HTTP,signingSecretStatus.configured_unavailablesignifica que la cuenta está configurada mediante SecretRef, pero la ruta actual de comando/runtime no pudo resolver el valor secreto. configWrites: falsebloquea escrituras de configuración iniciadas desde Slack.channels.slack.defaultAccountopcional anula la selección de la cuenta predeterminada cuando coincide con un id de cuenta configurado.channels.slack.streaming.modees la clave canónica del modo de transmisión de Slack.channels.slack.streaming.nativeTransportcontrola el transporte de transmisión nativo de Slack. Los valores heredadosstreamMode,streamingbooleano ynativeStreamingsiguen siendo alias de runtime; ejecutaopenclaw doctor --fixpara reescribir la configuración persistida.unfurlLinksyunfurlMediapasan los booleanos de despliegue de enlaces y medios dechat.postMessagede Slack para respuestas del bot. Omítelos para mantener el comportamiento predeterminado de Slack; establécelos enchannels.slack.accounts.<accountId>para anular el valor predeterminado de nivel superior de una cuenta.- Usa
user:<id>(DM) ochannel:<id>para los destinos de entrega.
off, own (predeterminado), all, allowlist (desde reactionAllowlist).
Aislamiento de sesiones por hilo: thread.historyScope es por hilo (predeterminado) o compartido en todo el canal. thread.inheritParent copia la transcripción del canal principal a hilos nuevos.
- La transmisión nativa de Slack más el estado de hilo estilo asistente de Slack “is typing…” requieren un destino de hilo de respuesta. Los DM de nivel superior permanecen fuera de hilo de forma predeterminada, por lo que aún pueden transmitirse mediante vistas previas de borrador publicar-y-editar de Slack en lugar de mostrar la vista previa nativa de transmisión/estado estilo hilo.
typingReactionagrega una reacción temporal al mensaje entrante de Slack mientras se ejecuta una respuesta, y luego la elimina al completarse. Usa un shortcode de emoji de Slack como"hourglass_flowing_sand".channels.slack.execApprovals: entrega de aprobaciones de exec nativa de Slack y autorización de aprobadores. Mismo esquema que Discord:enabled(true/false/"auto"),approvers(ID de usuario de Slack),agentFilter,sessionFilterytarget("dm","channel"o"both").
| Grupo de acciones | Predeterminado | Notas |
|---|---|---|
| reactions | habilitado | Reaccionar + listar reacciones |
| messages | habilitado | Leer/enviar/editar/eliminar |
| pins | habilitado | Fijar/desfijar/listar |
| memberInfo | habilitado | Información del miembro |
| emojiList | habilitado | Lista de emojis personalizados |
Mattermost
Mattermost se distribuye como Plugin incluido en las versiones actuales de OpenClaw. Las compilaciones anteriores o personalizadas pueden instalar un paquete npm actual conopenclaw plugins install @openclaw/mattermost. Consulta
npmjs.com/package/@openclaw/mattermost
para ver los dist-tags actuales antes de fijar una versión.
oncall (responde con @-mención, predeterminado), onmessage (cada mensaje), onchar (mensajes que empiezan con el prefijo activador).
Cuando los comandos nativos de Mattermost están habilitados:
commands.callbackPathdebe ser una ruta (por ejemplo/api/channels/mattermost/command), no una URL completa.commands.callbackUrldebe resolverse al endpoint del Gateway de OpenClaw y ser accesible desde el servidor Mattermost.- Las callbacks nativas de barra diagonal se autentican con los tokens por comando devueltos
por Mattermost durante el registro de comandos de barra diagonal. Si el registro falla o no
se activa ningún comando, OpenClaw rechaza las callbacks con
Unauthorized: invalid command token. - Para hosts de callback privados/tailnet/internos, Mattermost puede requerir que
ServiceSettings.AllowedUntrustedInternalConnectionsincluya el host/dominio de callback. Usa valores de host/dominio, no URLs completas. channels.mattermost.configWrites: permite o deniega escrituras de configuración iniciadas por Mattermost.channels.mattermost.requireMention: requiere@mentionantes de responder en canales.channels.mattermost.groups.<channelId>.requireMention: anulación por canal de la compuerta por mención ("*"para el valor predeterminado).- El
channels.mattermost.defaultAccountopcional anula la selección de cuenta predeterminada cuando coincide con un id de cuenta configurado.
Signal
off, own (predeterminado), all, allowlist (desde reactionAllowlist).
channels.signal.account: fija el inicio del canal a una identidad de cuenta de Signal específica.channels.signal.configWrites: permite o deniega escrituras de configuración iniciadas por Signal.- El
channels.signal.defaultAccountopcional anula la selección de cuenta predeterminada cuando coincide con un id de cuenta configurado.
iMessage
OpenClaw iniciaimsg rpc (JSON-RPC por stdio). No se requiere daemon ni puerto. Esta es la ruta preferida para las nuevas configuraciones de iMessage de OpenClaw cuando el host puede conceder permisos de base de datos de Messages y Automation.
Se eliminó el soporte de BlueBubbles. channels.bluebubbles no es una superficie de configuración de runtime compatible en el OpenClaw actual. Migra las configuraciones antiguas a channels.imessage; usa Eliminación de BlueBubbles y la ruta de iMessage de imsg para la versión breve y Venir desde BlueBubbles para la tabla de traducción completa.
Si el Gateway no se ejecuta en el Mac con sesión iniciada en Messages, mantén channels.imessage.enabled=true y configura channels.imessage.cliPath como un contenedor SSH que ejecute imsg "$@" en ese Mac. La ruta local predeterminada de imsg es solo para macOS.
-
El
channels.imessage.defaultAccountopcional anula la selección de cuenta predeterminada cuando coincide con un id de cuenta configurado. - Requiere Full Disk Access a la base de datos de Messages.
-
Prefiere destinos
chat_id:<id>. Usaimsg chats --limit 20para listar chats. -
cliPathpuede apuntar a un contenedor SSH; configuraremoteHost(hostouser@host) para obtener adjuntos mediante SCP. -
attachmentRootsyremoteAttachmentRootsrestringen las rutas de adjuntos entrantes (predeterminado:/Users/*/Library/Messages/Attachments). -
SCP usa comprobación estricta de claves de host, así que asegúrate de que la clave del host de retransmisión ya exista en
~/.ssh/known_hosts. -
channels.imessage.configWrites: permite o deniega escrituras de configuración iniciadas por iMessage. -
channels.imessage.actions.*: habilita acciones de API privada que también están controladas porimsg status/openclaw channels status --probe. -
channels.imessage.includeAttachmentsestá desactivado de forma predeterminada; establécelo entrueantes de esperar medios entrantes en turnos del agente. -
channels.imessage.catchup.enabled: opta por reproducir mensajes entrantes que llegaron mientras el Gateway estaba caído. -
channels.imessage.groups: registro de grupos y configuración por grupo. CongroupPolicy: "allowlist", configura claveschat_idexplícitas o una entrada comodín"*"para que los mensajes de grupo puedan pasar la compuerta del registro. -
Las entradas de nivel superior
bindings[]contype: "acp"pueden vincular conversaciones de iMessage a sesiones ACP persistentes. Usa un identificador normalizado o un destino de chat explícito (chat_id:*,chat_guid:*,chat_identifier:*) enmatch.peer.id. Semántica de campos compartidos: Agentes ACP.
Ejemplo de contenedor SSH de iMessage
Ejemplo de contenedor SSH de iMessage
Matrix
Matrix está respaldado por Plugin y se configura enchannels.matrix.
- La autenticación con token usa
accessToken; la autenticación con contraseña usauserId+password. channels.matrix.proxyenruta el tráfico HTTP de Matrix a través de un proxy HTTP(S) explícito. Las cuentas con nombre pueden anularlo conchannels.matrix.accounts.<id>.proxy.channels.matrix.network.dangerouslyAllowPrivateNetworkpermite homeservers privados/internos.proxyy esta opción de red son controles independientes.channels.matrix.defaultAccountselecciona la cuenta preferida en configuraciones con varias cuentas.channels.matrix.autoJoinse establece de forma predeterminada enoff, por lo que las salas invitadas y las invitaciones nuevas de tipo DM se ignoran hasta que configuresautoJoin: "allowlist"conautoJoinAllowlistoautoJoin: "always".channels.matrix.execApprovals: entrega de aprobaciones de exec nativa de Matrix y autorización de aprobadores.enabled:true,falseo"auto"(predeterminado). En modo automático, las aprobaciones de exec se activan cuando los aprobadores se pueden resolver desdeapproversocommands.ownerAllowFrom.approvers: ids de usuario de Matrix (por ejemplo@owner:example.org) autorizados para aprobar solicitudes de exec.agentFilter: lista de permitidos opcional de ids de agente. Omítelo para reenviar aprobaciones de todos los agentes.sessionFilter: patrones opcionales de clave de sesión (subcadena o regex).target: dónde enviar las solicitudes de aprobación."dm"(predeterminado),"channel"(sala de origen) o"both".- Anulaciones por cuenta:
channels.matrix.accounts.<id>.execApprovals.
channels.matrix.dm.sessionScopecontrola cómo los DM de Matrix se agrupan en sesiones:per-user(predeterminado) comparte por par enrutado, mientras queper-roomaísla cada sala de DM.- Las sondas de estado de Matrix y las búsquedas en vivo de directorio usan la misma política de proxy que el tráfico en runtime.
- La configuración completa de Matrix, las reglas de destino y los ejemplos de configuración están documentados en Matrix.
Microsoft Teams
Microsoft Teams está respaldado por Plugin y se configura enchannels.msteams.
- Rutas de clave principales cubiertas aquí:
channels.msteams,channels.msteams.configWrites. - La configuración completa de Teams (credenciales, webhook, política de DM/grupo, anulaciones por equipo/por canal) está documentada en Microsoft Teams.
IRC
IRC está respaldado por Plugin y se configura enchannels.irc.
- Rutas de clave principales cubiertas aquí:
channels.irc,channels.irc.dmPolicy,channels.irc.configWrites,channels.irc.nickserv.*. - El
channels.irc.defaultAccountopcional anula la selección de cuenta predeterminada cuando coincide con un id de cuenta configurado. - La configuración completa del canal IRC (host/puerto/TLS/canales/listas de permitidos/compuerta por mención) está documentada en IRC.
Varias cuentas (todos los canales)
Ejecuta varias cuentas por canal (cada una con su propioaccountId):
defaultse usa cuando se omiteaccountId(CLI + enrutamiento).- Los tokens de env solo se aplican a la cuenta predeterminada.
- La configuración base del canal se aplica a todas las cuentas salvo que se anule por cuenta.
- Usa
bindings[].match.accountIdpara enrutar cada cuenta a un agente distinto. - Si agregas una cuenta no predeterminada mediante
openclaw channels add(o incorporación de canales) mientras sigues en una configuración de canal de nivel superior con una sola cuenta, OpenClaw primero promueve los valores de una sola cuenta de nivel superior con alcance de cuenta al mapa de cuentas del canal para que la cuenta original siga funcionando. La mayoría de los canales los mueve achannels.<channel>.accounts.default; Matrix puede conservar en su lugar un destino con nombre/predeterminado coincidente existente. - Los enlaces existentes solo de canal (sin
accountId) siguen coincidiendo con la cuenta predeterminada; los enlaces con alcance de cuenta siguen siendo opcionales. openclaw doctor --fixtambién repara formas mixtas moviendo los valores de una sola cuenta de nivel superior con alcance de cuenta a la cuenta promovida elegida para ese canal. La mayoría de los canales usaaccounts.default; Matrix puede conservar en su lugar un destino con nombre/predeterminado coincidente existente.
Otros canales Plugin
Muchos canales Plugin se configuran comochannels.<id> y se documentan en sus páginas de canal dedicadas (por ejemplo Feishu, Matrix, LINE, Nostr, Zalo, Nextcloud Talk, Synology Chat y Twitch).
Consulta el índice completo de canales: Canales.
Compuerta por mención en chat grupal
Los mensajes de grupo requieren mención obligatoria de forma predeterminada (mención de metadatos o patrones regex seguros). Se aplica a chats grupales de WhatsApp, Telegram, Discord, Google Chat e iMessage. Las respuestas visibles se controlan por separado. Las salas de grupo/canal usan de forma predeterminadamessages.groupChat.visibleReplies: "message_tool": OpenClaw sigue procesando el turno, pero las respuestas finales normales permanecen privadas y la salida visible en la sala requiere message(action=send). Configura "automatic" solo cuando quieras el comportamiento heredado en el que las respuestas normales se publican de vuelta en la sala. Para aplicar también a los chats directos el mismo comportamiento de respuesta visible solo mediante herramienta, configura messages.visibleReplies: "message_tool"; el harness de Codex también usa ese comportamiento solo mediante herramienta como valor predeterminado no configurado para chats directos.
Las respuestas visibles solo mediante herramienta requieren un modelo/runtime que invoque herramientas de forma fiable. Si
el registro de la sesión muestra texto del asistente con didSendViaMessagingTool: false, el
modelo produjo una respuesta final privada en lugar de invocar la herramienta de mensajes.
Cambia a un modelo con invocación de herramientas más sólido para ese canal, o configura
messages.groupChat.visibleReplies: "automatic" para restaurar las respuestas finales visibles
heredadas.
Si la herramienta de mensajes no está disponible con la política de herramientas activa, OpenClaw vuelve a respuestas visibles automáticas en lugar de suprimir silenciosamente la respuesta. openclaw doctor advierte sobre esta incompatibilidad.
El Gateway recarga en caliente la configuración de messages después de guardar el archivo. Reinicia solo cuando la observación de archivos o la recarga de configuración esté deshabilitada en el despliegue.
Tipos de menciones:
- Menciones de metadatos: @-menciones nativas de la plataforma. Se ignoran en el modo de chat propio de WhatsApp.
- Patrones de texto: Patrones regex seguros en
agents.list[].groupChat.mentionPatterns. Se ignoran los patrones no válidos y la repetición anidada insegura. - La compuerta por mención se aplica solo cuando la detección es posible (menciones nativas o al menos un patrón).
messages.groupChat.historyLimit establece el valor predeterminado global. Los canales pueden sobrescribirlo con channels.<channel>.historyLimit (o por cuenta). Configura 0 para deshabilitarlo.
messages.visibleReplies es el valor predeterminado global para turnos de origen; messages.groupChat.visibleReplies lo sobrescribe para turnos de origen de grupo/canal. Cuando messages.visibleReplies no está configurado, un harness puede proporcionar su propio valor predeterminado para directos/origen; el harness de Codex usa message_tool de forma predeterminada. Las listas de permitidos de canales y la compuerta por mención siguen decidiendo si se procesa un turno.
Límites del historial de DM
telegram, whatsapp, discord, slack, signal, imessage, msteams.
Modo de chat propio
Incluye tu propio número enallowFrom para habilitar el modo de chat propio (ignora las @-menciones nativas, solo responde a patrones de texto):
Comandos (manejo de comandos de chat)
Detalles de los comandos
Detalles de los comandos
- Este bloque configura las superficies de comandos. Para ver el catálogo actual de comandos integrados y empaquetados, consulta Comandos Slash.
- Esta página es una referencia de claves de configuración, no el catálogo completo de comandos. Los comandos propiedad de canales/plugins, como
/bot-ping/bot-help/bot-logsde QQ Bot,/cardde LINE,/pairde emparejamiento de dispositivos,/dreamingde memoria,/phonede control telefónico y/voicede Talk, están documentados en sus páginas de canal/plugin más Comandos Slash. - Los comandos de texto deben ser mensajes independientes con
/inicial. native: "auto"activa los comandos nativos para Discord/Telegram y deja Slack desactivado.nativeSkills: "auto"activa los comandos nativos de Skills para Discord/Telegram y deja Slack desactivado.- Sobrescritura por canal:
channels.discord.commands.native(bool o"auto"). Para Discord,falseomite el registro y la limpieza de comandos nativos durante el inicio. - Sobrescribe el registro nativo de Skills por canal con
channels.<provider>.commands.nativeSkills. channels.telegram.customCommandsañade entradas adicionales al menú del bot de Telegram.bash: truehabilita! <cmd>para la shell del host. Requieretools.elevated.enabledy que el remitente esté entools.elevated.allowFrom.<channel>.config: truehabilita/config(lee/escribeopenclaw.json). Para clienteschat.senddel Gateway, las escrituras persistentes de/config set|unsettambién requierenoperator.admin;/config showde solo lectura sigue disponible para clientes operador normales con alcance de escritura.mcp: truehabilita/mcppara la configuración de servidores MCP administrados por OpenClaw enmcp.servers.plugins: truehabilita/pluginspara descubrimiento, instalación y controles de habilitar/deshabilitar plugins.channels.<provider>.configWritescontrola las mutaciones de configuración por canal (valor predeterminado: true).- Para canales con varias cuentas,
channels.<provider>.accounts.<id>.configWritestambién controla las escrituras que apuntan a esa cuenta (por ejemplo,/allowlist --config --account <id>o/config set channels.<provider>.accounts.<id>...). restart: falsedeshabilita/restarty las acciones de herramienta de reinicio del Gateway. Valor predeterminado:true.ownerAllowFromes la lista de permitidos explícita del propietario para comandos/herramientas solo de propietario. Es independiente deallowFrom.ownerDisplay: "hash"hashea los ids de propietario en el prompt del sistema. ConfiguraownerDisplaySecretpara controlar el hashing.allowFromes por proveedor. Cuando se configura, es la única fuente de autorización (se ignoran las listas de permitidos/emparejamiento de canales yuseAccessGroups).useAccessGroups: falsepermite que los comandos omitan las políticas de grupos de acceso cuandoallowFromno está configurado.- Mapa de documentación de comandos:
- catálogo integrado y empaquetado: Comandos Slash
- superficies de comandos específicas de canal: Canales
- comandos de QQ Bot: QQ Bot
- comandos de emparejamiento: Emparejamiento
- comando de tarjeta de LINE: LINE
- Dreaming de memoria: Dreaming
Relacionado
- Referencia de configuración — claves de nivel superior
- Configuración — agentes
- Resumen de canales