Regional platforms
LINE
LINE підключається до OpenClaw через LINE Messaging API. Plugin працює як приймач Webhook на Gateway і використовує ваш channel access token + channel secret для автентифікації.
Статус: завантажуваний Plugin. Підтримуються прямі повідомлення, групові чати, медіа, локації, повідомлення Flex, шаблонні повідомлення та швидкі відповіді. Реакції та гілки не підтримуються.
Встановлення
Встановіть LINE перед налаштуванням каналу:
openclaw plugins install @openclaw/lineЛокальний checkout (під час запуску з git-репозиторію):
openclaw plugins install ./path/to/local/line-pluginНалаштування
- Створіть обліковий запис LINE Developers і відкрийте Console: https://developers.line.biz/console/
- Створіть (або виберіть) Provider і додайте канал Messaging API.
- Скопіюйте Channel access token і Channel secret з налаштувань каналу.
- Увімкніть Use webhook у налаштуваннях Messaging API.
- Установіть URL Webhook на кінцеву точку вашого Gateway (потрібен HTTPS):
https://gateway-host/line/webhookGateway відповідає на перевірку Webhook від LINE (GET) і підтверджує підписані
вхідні події (POST) одразу після перевірки підпису та payload; обробка агентом
продовжується асинхронно.
Якщо вам потрібен власний шлях, задайте channels.line.webhookPath або
channels.line.accounts.<id>.webhookPath і відповідно оновіть URL.
Примітка щодо безпеки:
- Перевірка підпису LINE залежить від тіла запиту (HMAC над raw body), тому OpenClaw застосовує суворі ліміти тіла до автентифікації та timeout перед перевіркою.
- OpenClaw обробляє події Webhook з перевірених raw bytes запиту. Значення
req.body, перетворені upstream middleware, ігноруються для безпеки цілісності підпису.
Конфігурація
Мінімальна конфігурація:
{ channels: { line: { enabled: true, channelAccessToken: "LINE_CHANNEL_ACCESS_TOKEN", channelSecret: "LINE_CHANNEL_SECRET", dmPolicy: "pairing", }, },}Публічна конфігурація DM:
{ channels: { line: { enabled: true, channelAccessToken: "LINE_CHANNEL_ACCESS_TOKEN", channelSecret: "LINE_CHANNEL_SECRET", dmPolicy: "open", allowFrom: ["*"], }, },}Змінні env (лише обліковий запис за замовчуванням):
LINE_CHANNEL_ACCESS_TOKENLINE_CHANNEL_SECRET
Файли token/secret:
{ channels: { line: { tokenFile: "/path/to/line-token.txt", secretFile: "/path/to/line-secret.txt", }, },}tokenFile і secretFile мають вказувати на звичайні файли. Symlinks відхиляються.
Кілька облікових записів:
{ channels: { line: { accounts: { marketing: { channelAccessToken: "...", channelSecret: "...", webhookPath: "/line/marketing", }, }, }, },}Контроль доступу
Прямі повідомлення за замовчуванням використовують сполучення. Невідомі відправники отримують код сполучення, а їхні повідомлення ігноруються, доки їх не буде схвалено.
openclaw pairing list lineopenclaw pairing approve line <CODE>Списки дозволених і політики:
channels.line.dmPolicy:pairing | allowlist | open | disabledchannels.line.allowFrom: дозволені ідентифікатори користувачів LINE для приватних повідомлень;dmPolicy: "open"вимагає["*"]channels.line.groupPolicy:allowlist | open | disabledchannels.line.groupAllowFrom: дозволені ідентифікатори користувачів LINE для груп- Перевизначення для окремих груп:
channels.line.groups.<groupId>.allowFrom - Статичні групи доступу відправників можна посилатися з
allowFrom,groupAllowFromі груповогоallowFromчерезaccessGroup:<name>. - Примітка щодо runtime: якщо
channels.lineповністю відсутній, runtime повертається доgroupPolicy="allowlist"для перевірок груп (навіть якщо заданоchannels.defaults.groupPolicy).
Ідентифікатори LINE чутливі до регістру. Коректні ідентифікатори мають такий вигляд:
- Користувач:
U+ 32 шістнадцяткові символи - Група:
C+ 32 шістнадцяткові символи - Кімната:
R+ 32 шістнадцяткові символи
Поведінка повідомлень
- Текст розбивається на фрагменти по 5000 символів.
- Форматування Markdown вилучається; блоки коду й таблиці за можливості перетворюються на Flex картки.
- Потокові відповіді буферизуються; LINE отримує повні фрагменти з анімацією завантаження, поки агент працює.
- Завантаження медіа обмежуються
channels.line.mediaMaxMb(за замовчуванням 10). - Вхідні медіа зберігаються в
~/.openclaw/media/inbound/перед передаванням агенту, відповідно до спільного сховища медіа, яке використовують інші вбудовані plugins каналів.
Дані каналу (розширені повідомлення)
Використовуйте channelData.line, щоб надсилати швидкі відповіді, локації, Flex картки або шаблонні
повідомлення.
{ 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", }, }, },}LINE plugin також постачається з командою /card для пресетів Flex повідомлень:
/card info "Welcome" "Thanks for joining!"Підтримка ACP
LINE підтримує прив’язки розмов ACP (Agent Communication Protocol):
/acp spawn <agent> --bind hereприв’язує поточний чат LINE до сесії ACP без створення дочірньої гілки.- Налаштовані прив’язки ACP й активні сесії ACP, прив’язані до розмов, працюють у LINE так само, як в інших розмовних каналах.
Докладніше див. агенти ACP.
Вихідні медіа
LINE plugin підтримує надсилання зображень, відео й аудіофайлів через інструмент повідомлень агента. Медіа надсилаються через специфічний для LINE шлях доставки з відповідною обробкою попереднього перегляду й відстеження:
- Зображення: надсилаються як повідомлення із зображеннями LINE з автоматичним створенням попереднього перегляду.
- Відео: надсилаються з явною обробкою попереднього перегляду й типу вмісту.
- Аудіо: надсилаються як аудіоповідомлення LINE.
URL-адреси вихідних медіа мають бути публічними HTTPS URL-адресами. OpenClaw перевіряє цільове ім’я хоста перед передаванням URL-адреси до LINE і відхиляє loopback, link-local і цілі в приватних мережах.
Універсальне надсилання медіа повертається до наявного маршруту лише для зображень, коли специфічний для LINE шлях недоступний.
Усунення несправностей
- Перевірка Webhook не вдається: переконайтеся, що URL-адреса webhook використовує HTTPS і що
channelSecretзбігається з консоллю LINE. - Немає вхідних подій: підтвердьте, що шлях webhook збігається з
channels.line.webhookPathі що gateway доступний із LINE. - Помилки завантаження медіа: збільште
channels.line.mediaMaxMb, якщо медіа перевищує стандартний ліміт.
Пов’язане
- Огляд каналів — усі підтримувані канали
- Сполучення — автентифікація приватних повідомлень і потік сполучення
- Групи — поведінка групового чату й обмеження за згадками
- Маршрутизація каналів — маршрутизація сесій для повідомлень
- Безпека — модель доступу й посилення захисту