Regional platforms
LÍNEA
LINE se conecta a OpenClaw mediante la API de mensajería de LINE. El Plugin se ejecuta como receptor de Webhook en el Gateway y usa tu token de acceso del canal + secreto del canal para la autenticación.
Estado: Plugin descargable. Se admiten mensajes directos, chats de grupo, medios, ubicaciones, mensajes Flex, mensajes de plantilla y respuestas rápidas. No se admiten reacciones ni hilos.
Instalar
Instala LINE antes de configurar el canal:
openclaw plugins install @openclaw/line
Checkout local (al ejecutar desde un repositorio git):
openclaw plugins install ./path/to/local/line-plugin
Configuración
- Crea una cuenta de LINE Developers y abre la consola: https://developers.line.biz/console/
- Crea (o elige) un proveedor y añade un canal de Messaging API.
- Copia el token de acceso del canal y el secreto del canal desde la configuración del canal.
- Activa Usar webhook en la configuración de Messaging API.
- Establece la URL del Webhook en tu endpoint del Gateway (se requiere HTTPS):
https://gateway-host/line/webhook
El Gateway responde a la verificación del Webhook de LINE (GET) y a los eventos entrantes (POST).
Si necesitas una ruta personalizada, establece channels.line.webhookPath o
channels.line.accounts.<id>.webhookPath y actualiza la URL según corresponda.
Nota de seguridad:
- La verificación de firma de LINE depende del cuerpo (HMAC sobre el cuerpo sin procesar), por lo que OpenClaw aplica límites estrictos del cuerpo previos a la autenticación y tiempo de espera antes de la verificación.
- OpenClaw procesa los eventos de Webhook a partir de los bytes sin procesar verificados de la solicitud. Los valores de
req.bodytransformados por middleware anterior se ignoran para proteger la integridad de la firma.
Configurar
Configuración mínima:
{
channels: {
line: {
enabled: true,
channelAccessToken: "LINE_CHANNEL_ACCESS_TOKEN",
channelSecret: "LINE_CHANNEL_SECRET",
dmPolicy: "pairing",
},
},
}
Configuración de DM pública:
{
channels: {
line: {
enabled: true,
channelAccessToken: "LINE_CHANNEL_ACCESS_TOKEN",
channelSecret: "LINE_CHANNEL_SECRET",
dmPolicy: "open",
allowFrom: ["*"],
},
},
}
Variables de entorno (solo cuenta predeterminada):
LINE_CHANNEL_ACCESS_TOKENLINE_CHANNEL_SECRET
Archivos de token/secreto:
{
channels: {
line: {
tokenFile: "/path/to/line-token.txt",
secretFile: "/path/to/line-secret.txt",
},
},
}
tokenFile y secretFile deben apuntar a archivos normales. Los enlaces simbólicos se rechazan.
Varias cuentas:
{
channels: {
line: {
accounts: {
marketing: {
channelAccessToken: "...",
channelSecret: "...",
webhookPath: "/line/marketing",
},
},
},
},
}
Control de acceso
Los mensajes directos usan emparejamiento de forma predeterminada. Los remitentes desconocidos reciben un código de emparejamiento y sus mensajes se ignoran hasta que se aprueban.
openclaw pairing list line
openclaw pairing approve line <CODE>
Listas de permitidos y políticas:
channels.line.dmPolicy:pairing | allowlist | open | disabledchannels.line.allowFrom: IDs de usuario de LINE permitidos para DM;dmPolicy: "open"requiere["*"]channels.line.groupPolicy:allowlist | open | disabledchannels.line.groupAllowFrom: IDs de usuario de LINE permitidos para grupos- Sobrescrituras por grupo:
channels.line.groups.<groupId>.allowFrom - Nota de ejecución: si falta por completo
channels.line, el runtime recurre agroupPolicy="allowlist"para las comprobaciones de grupo (aunquechannels.defaults.groupPolicyesté establecido).
Los IDs de LINE distinguen mayúsculas y minúsculas. Los IDs válidos tienen este aspecto:
- Usuario:
U+ 32 caracteres hexadecimales - Grupo:
C+ 32 caracteres hexadecimales - Sala:
R+ 32 caracteres hexadecimales
Comportamiento de los mensajes
- El texto se divide en fragmentos de 5000 caracteres.
- Se elimina el formato Markdown; los bloques de código y las tablas se convierten en tarjetas Flex cuando es posible.
- Las respuestas en streaming se almacenan en búfer; LINE recibe fragmentos completos con una animación de carga mientras el agente trabaja.
- Las descargas de medios tienen un límite definido por
channels.line.mediaMaxMb(predeterminado 10). - Los medios entrantes se guardan en
~/.openclaw/media/inbound/antes de pasarse al agente, coincidiendo con el almacén de medios compartido que usan otros plugins de canal incluidos.
Datos de canal (mensajes enriquecidos)
Usa channelData.line para enviar respuestas rápidas, ubicaciones, tarjetas Flex o mensajes de plantilla.
{
text: "Here you go",
channelData: {
line: {
quickReplies: ["Status", "Help"],
location: {
title: "Office",
address: "123 Main St",
latitude: 35.681236,
longitude: 139.767125,
},
flexMessage: {
altText: "Status card",
contents: {
/* Flex payload */
},
},
templateMessage: {
type: "confirm",
text: "Proceed?",
confirmLabel: "Yes",
confirmData: "yes",
cancelLabel: "No",
cancelData: "no",
},
},
},
}
El Plugin de LINE también incluye un comando /card para preajustes de mensajes Flex:
/card info "Welcome" "Thanks for joining!"
Compatibilidad con ACP
LINE admite vinculaciones de conversación de ACP (Agent Communication Protocol):
/acp spawn <agent> --bind herevincula el chat actual de LINE a una sesión de ACP sin crear un hilo secundario.- Las vinculaciones de ACP configuradas y las sesiones de ACP activas vinculadas a conversaciones funcionan en LINE igual que en otros canales de conversación.
Consulta agentes de ACP para más detalles.
Medios salientes
El Plugin de LINE admite enviar imágenes, videos y archivos de audio mediante la herramienta de mensajes del agente. Los medios se envían a través de la ruta de entrega específica de LINE con la gestión adecuada de vista previa y seguimiento:
- Imágenes: se envían como mensajes de imagen de LINE con generación automática de vista previa.
- Videos: se envían con gestión explícita de vista previa y tipo de contenido.
- Audio: se envía como mensajes de audio de LINE.
Las URL de medios salientes deben ser URL HTTPS públicas. OpenClaw valida el nombre de host de destino antes de entregar la URL a LINE y rechaza objetivos de loopback, link-local y redes privadas.
Los envíos de medios genéricos recurren a la ruta existente solo para imágenes cuando no hay una ruta específica de LINE disponible.
Solución de problemas
- La verificación del Webhook falla: asegúrate de que la URL del Webhook use HTTPS y que
channelSecretcoincida con la consola de LINE. - No hay eventos entrantes: confirma que la ruta del Webhook coincida con
channels.line.webhookPathy que LINE pueda acceder al Gateway. - Errores de descarga de medios: aumenta
channels.line.mediaMaxMbsi los medios superan el límite predeterminado.
Relacionado
- Resumen de canales — todos los canales admitidos
- Emparejamiento — autenticación de DM y flujo de emparejamiento
- Grupos — comportamiento de chats de grupo y control por menciones
- Enrutamiento de canales — enrutamiento de sesiones para mensajes
- Seguridad — modelo de acceso y endurecimiento