LINE Messaging API plugin for ElizaOS agents. Enables chatbot integration with LINE, a popular messaging platform in Japan, Taiwan, and Thailand.
- Text Messages: Send and receive text messages
- Rich Messages (Flex): Create visually rich card messages
- Location Messages: Share locations with map pins
- Quick Replies: Provide suggested reply options
- Group/Room Support: Operate in groups and multi-user rooms
- User Profiles: Access user display names, pictures, and language
- Webhook Integration: Receive messages via LINE webhooks
- Multi-language Support: Available in TypeScript, Python, and Rust
# npm
npm install @elizaos/plugin-line
# pnpm
pnpm add @elizaos/plugin-line| Variable | Description | Required |
|---|---|---|
LINE_CHANNEL_ACCESS_TOKEN |
Channel access token from LINE Developers Console | Yes |
LINE_CHANNEL_SECRET |
Channel secret for webhook verification | Yes |
LINE_WEBHOOK_PATH |
Webhook endpoint path | No |
LINE_DM_POLICY |
DM policy: open, pairing, allowlist, disabled | No |
LINE_GROUP_POLICY |
Group policy: open, allowlist, disabled | No |
LINE_ALLOW_FROM |
Comma-separated user IDs for allowlist | No |
LINE_ENABLED |
Enable/disable the plugin | No |
{
"plugins": ["@elizaos/plugin-line"],
"pluginParameters": {
"LINE_CHANNEL_ACCESS_TOKEN": "your-channel-access-token",
"LINE_CHANNEL_SECRET": "your-channel-secret",
"LINE_DM_POLICY": "pairing",
"LINE_GROUP_POLICY": "allowlist"
}
}- Create a LINE Developers account at https://developers.line.biz/
- Create a new Messaging API channel
- Get your Channel Access Token (issue a long-lived token)
- Get your Channel Secret
- Set up webhook URL pointing to your server
Send a text message to a user, group, or room.
"Send them a message saying 'Hello!'"
"Message the group saying 'Meeting in 5 minutes'"
Send a rich flex message card.
"Send them an info card with title 'Update' and body 'New features available'"
Send a location message with map pin.
"Send them the location of Tokyo Tower"
Provides information about the current chat:
- Chat type (user/group/room)
- Chat ID
- Group name and member count (for groups)
Provides information about the current user:
- User ID
- Display name
- Profile picture URL
- Status message
- Language preference
- User IDs: Start with
Ufollowed by 32 hex characters (e.g.,U1234567890abcdef1234567890abcdef) - Group IDs: Start with
Cfollowed by 32 hex characters - Room IDs: Start with
Rfollowed by 32 hex characters
- Text messages: 5000 characters max
- Alt text (for flex/template): 400 characters max
- Location title/address: 100 characters max
- Messages per push: 5 max (batched automatically)
- Configure your webhook URL in the LINE Developers Console
- Ensure your server verifies webhook signatures using the channel secret
- The plugin provides middleware for Express-style webhook handling
import { LineService } from "@elizaos/plugin-line";
// Get the middleware
const middleware = lineService.createMiddleware();
// Use with Express
app.post("/webhooks/line", middleware, async (req, res) => {
const events = req.body.events;
await lineService.handleWebhookEvents(events);
res.status(200).end();
});LINE Flex Messages allow rich visual content. The plugin supports creating info card bubbles:
const flexMessage = {
altText: "Update Notification",
contents: {
type: "bubble",
body: {
type: "box",
layout: "vertical",
contents: [
{ type: "text", text: "Title", weight: "bold", size: "xl" },
{ type: "text", text: "Body content", margin: "md", wrap: true }
]
}
}
};| Policy | Description |
|---|---|
open |
Accept DMs from anyone |
pairing |
Accept DMs and remember senders |
allowlist |
Only accept from LINE_ALLOW_FROM list |
disabled |
Don't accept any DMs |
| Policy | Description |
|---|---|
open |
Respond to anyone in groups |
allowlist |
Only respond to allowed users |
disabled |
Don't respond in groups |
# TypeScript
cd typescript && npm run build
# Python
cd python && pip install -e .
# Rust
cd rust && cargo build# TypeScript
npm test
# Python
pytest
# Rust
cargo testisConnected(): Check connection statusgetBotInfo(): Get bot profilesendMessage(to, text, options?): Send text messagesendFlexMessage(to, flex): Send flex messagesendTemplateMessage(to, template): Send template messagesendLocationMessage(to, location): Send locationreplyMessage(replyToken, messages): Reply using tokengetUserProfile(userId): Get user profilegetGroupInfo(groupId): Get group infoleaveChat(chatId, chatType): Leave group/room
MIT