line-oa-mcp-ultimate
The line-oa-mcp-ultimate server lets AI agents manage a LINE Official Account through natural language. Key capabilities include:
📨 Messaging
Send text, Flex, sticker, image, video, or coupon messages to any target (reply, push, multicast, narrowcast, broadcast)
Three send modes:
send_now,draft(for scheduling), anddry_run(validate + estimate cost only)Built-in quota guardian, quiet-hours warnings, pre-flight validation, and retry-key handling
Find stickers by mood or keyword
🎨 Rich Menus
Create, list, delete, link/unlink (bulk up to 500 users), set/clear default, and upload images
Audit why a specific user sees a particular menu (priority chain inspection)
Manage rich menu aliases for tab-switching
💎 Message Design
Design Flex Messages from templates or raw JSON with preview URLs
Design Imagemap (Rich Messages) with tappable regions and optional inline video
Design Card Messages (buttons, confirm, carousel, image carousel)
🎯 Audiences
Build audiences from CSV (user ID upload) or prior broadcast engagement (clicks/opens)
List, update (add users or rename), and delete audience groups
📊 Insights & Reporting
Get OA status (friend count, quota, webhook status, default rich menu)
Get multi-day OA reports (delivery stats, follower trends, quota usage)
Get per-broadcast engagement stats (impressions, opens, clicks, CTR, per-URL breakdown)
Estimate send cost and monitor narrowcast delivery progress
🎟 Coupons
Create (percentage/fixed/explicit discount), list, get, discontinue native LINE coupons
Get coupon redemption stats and send coupons as messages
🔌 Webhook
Test the webhook endpoint (ping, HTTP status, latency, signature result)
Set or retrieve the webhook URL
👤 User & Operations
Fetch individual user profiles and list followers (cursor-paginated, region-gated)
List all configured OAs, switch the active OA at runtime
Run read-only tools across multiple OAs in parallel (agency bulk reporting)
💻 LIFF & Token
Manage LIFF apps (create, list, update, delete)
Verify access token expiry, bound client ID, and granted scope
🛍 LINE Shopping (Optional, opt-in)
Manage products (create, update, inventory, pricing)
Process orders (list, detail, fulfill, cancel, print parcel labels)
Generate checkout links and manage settlements
Allows AI agents to operate a LINE Official Account through natural language, including sending messages, managing rich menus, audiences, coupons, and more via LINE's Messaging API.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@line-oa-mcp-ultimateSummarize last week's LINE OA performance"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
LINE OA MCP Ultimate
Operate your LINE Official Account from any AI agent — through natural language.
Quick Start · What you can do · Configuration · Documentation
🇹🇭 คู่มือภาษาไทย: เริ่มต้น 5 นาที · Messaging — 34 tools · LINE Shopping — 14 tools
What is this?
line-oa-mcp-ultimate is a Model Context Protocol server that lets AI agents drive your LINE Official Account through natural conversation — no code, no API knowledge required.
Manage one OA or many — a single account needs just one env var, while agencies can register every client OA in one config file and switch between them with a single command (see Configuration).
It works with Claude Cowork, Claude Code, Cursor, Codex, ChatGPT desktop, OpenClaw, Hermes, or any MCP-compatible host.
Disclaimer: This is an independent open-source project. It is not affiliated with or endorsed by LY Corporation / LINE Corp. "LINE" is a registered trademark of LY Corporation, used here in a descriptive sense.
Related MCP server: MCP LINE Server
Why use it?
LINE OA Manager works well — but it's a web UI you have to log into, click through, and operate manually. With this MCP server, the same operations become natural-language requests in your AI host of choice:
Instead of clicking through LINE OA Manager... | Just say... |
Open broadcast composer → pick audience → write text → preview → schedule | "Send a Mother's Day promo to my Bangkok-based 25-44 female audience" |
Navigate Insight → Delivery → pick date range → screenshot | "Summarize last week's performance" |
Open Audience → create from upload → upload CSV → wait | "Create an audience from this CSV: customers_last_month.csv" |
Open Rich Menu → design tabs → upload images → set as default | "Build a Mother's Day rich menu and set it as default" |
Open Coupon → check usage tab → cross-reference clicks | "How many people redeemed my Mother's Day coupon?" |
The MCP server takes care of LINE Messaging API calls, pre-flight validation, quota safety, quiet-hour warnings, and Thai-localized templates. You stay in your AI host and operate your OA the way you think about it — by intent.
Who is it for?
🪐 AI-first marketers who run a LINE OA from their AI workspace.
🏪 SMB owners who already use LINE OA as their primary customer channel and want to automate routine work.
🏢 Marketing agencies managing many client OAs from one dashboard.
💻 Developers building LINE-integrated SaaS, automations, or AI bots.
Free-tier ready — no Premium upgrade required for the core feature set.
What you can do
34 messaging tools + 14 LINE Shopping tools (v2.0, opt-in) + 4 resources + 7 guided prompts, grouped by what you actually want to do:
📨 Send messages (2 tools)
One universal send_message covers every LINE transport (reply / push / multicast / narrowcast / broadcast). Three modes: send_now, draft (for scheduling via LINE OA Manager UI), and dry_run (validate + estimate cost without sending). Message shapes: text, Flex (template or raw JSON), sticker, image, video, native LINE coupon ({ coupon_id }), and a message_json passthrough for pre-built Rich/Card messages. Plus Thai-friendly sticker search.
🎨 Rich Menus (8 tools)
Build a rich menu in one call (create + upload image + set as default), list, delete, and diagnose "why doesn't this user see my menu?". Full lifecycle too: link/unlink a menu to specific users or in bulk (auto-chunked at 500), set/clear the account default, manage rich-menu aliases (tab-switching menus), and swap the image on an existing menu.
💎 Message Design (3 tools)
Design Flex Messages from 8 Thai-localized templates or raw JSON, build Rich Messages (imagemap — tappable image regions + optional video), and Card Messages (template — buttons / confirm / carousel / image_carousel). Each returns ready-to-send JSON you hand to send_message.
🎯 Audiences (5 tools)
Build retargeting audiences from a CSV or from prior broadcast engagement, list, delete — and update an existing audience (add users, rename).
📊 Insights (5 tools)
Quick OA status snapshot (incl. chat mode), weekly markdown reports, per-broadcast engagement stats, pre-flight send-cost estimation, and narrowcast delivery progress ("did my blast finish?").
🎟 Coupons (2 tools)
Create, list, get, and discontinue native LINE coupons with line_manage_coupon, then broadcast a created coupon straight into chats as a native coupon message via send_message ({ coupon_id }). Pull redemption analytics by combining coupon details with click-audience tracking.
🔌 Webhook (2 tools)
Test your OA's webhook URL and surface LINE's signature verification result, plus set/get the webhook endpoint — quick to wire up or diagnose "why isn't my bot responding?".
👤 Operations (5 tools)
User profile lookup, follower listing, multi-OA listing and switching, and run_on_many_oas for agencies that need to run a read-only tool across all client OAs in parallel.
💻 LIFF & Token (2 tools)
Manage LIFF app lifecycle (create / update / delete / list) and verify your channel access token's validity, expiry, and scope.
🛍️ LINE Shopping (14 tools — v2.0, opt-in)
Turn your agent into a storefront operator. These register only when a MyShop API key is configured (see Configuration) — messaging-only users never see them. Powered by the MyShop Open API (X-API-KEY, no webhook/server required).
Products (7): list, create, update, delete, change price, show/hide, and manage variants — e.g. "เพิ่มสินค้าเสื้อยืด 299 บาท สต็อก 50", "ลดราคาคอลเลกชันนี้ 15%".
Inventory (1): set / increase / decrease stock — "เติมสต็อก V9 อีก 50".
Orders (4): list/search (with polling for new orders via a scheduled task), get detail, fulfill (mark shipped + tracking, mark COD paid, print parcel label), and cancel — "ออกใบปะหน้าให้ออเดอร์ที่จ่ายแล้ววันนี้".
Settlement + Checkout (2): see real income after fees, and create a checkout link to close the sale in chat — "ลูกค้าอยากได้ 2 ชิ้น สร้างลิงก์จ่ายเงิน".
📘 Full Thai guide: docs/myshop-guide-th.md — get the API key, every tool explained, real workflows, safety rules, and troubleshooting.
Resources — auto-refreshing OA snapshot, Flex template catalog, sticker catalog with mood-keyword index, and a Thai festival calendar with marketing promo patterns.
Prompts — guided workflows for daily reports, campaign building, broadcast scheduling, rich menu diagnosis, coupon campaigns, LINE Notify migration, and webhook setup.
Quick Start
Requirements
Node.js 20 or later
A LINE Official Account with Messaging API enabled
A Channel Access Token
No database, no Playwright, no CDN, no public URL, no scheduler infrastructure required.
Step 1 — Get your Channel Access Token
Open the LINE Developers Console.
Pick your provider → open (or create) a Messaging API channel.
Open the Messaging API tab → scroll to Channel access token → click Issue.
Copy the long-lived token. Treat it like a password.
If you don't yet have a LINE Official Account, follow LINE's getting started guide.
Step 2 — Add the MCP server to your AI host
Paste the following block into your host's MCP config file (see table below):
{
"mcpServers": {
"line": {
"command": "npx",
"args": ["-y", "line-oa-mcp-ultimate"],
"env": {
"LINE_CHANNEL_ACCESS_TOKEN": "YOUR_TOKEN_HERE"
}
}
}
}Where to find the config file:
Host | Where to add it |
Claude Cowork | Settings → Developer → Local MCP servers → Edit Config |
Claude Desktop (macOS) |
|
Claude Desktop (Windows) |
|
Claude Code | Run |
Cursor / Codex / ChatGPT desktop | See your host's MCP setup docs — same JSON shape |
⚠️ Don't replace existing MCP servers. Add the
"line"entry alongside any existing entries insidemcpServers.
Step 3 — Restart your AI host
Quit completely (Cmd+Q on macOS) and reopen. On first start the host runs npx -y line-oa-mcp-ultimate, downloads the package from npm, and caches it for subsequent starts.
Step 4 — Verify
In a new chat, try:
Show my LINE OA statusor in Thai:
ดูสถานะ OA หน่อยYou should see a health card with friend count, monthly quota, webhook status, and the default rich menu. That's it — you're now operating your LINE OA from your AI agent.
🛍️ Want LINE Shopping too? (optional)
Add LINE_MYSHOP_API_KEY to the same env block (get it from oaplus.line.biz → Settings → API keys, Admin role). The full config looks like this:
{
"mcpServers": {
"line": {
"command": "npx",
"args": ["-y", "line-oa-mcp-ultimate"],
"env": {
"LINE_CHANNEL_ACCESS_TOKEN": "YOUR_TOKEN_HERE",
"LINE_MYSHOP_API_KEY": "YOUR_MYSHOP_API_KEY_HERE"
}
}
}
}Restart your host — that unlocks 14 shopping tools (products, inventory, orders, parcel labels, settlements, checkout links). Without the key, the server stays messaging-only. See LINE Shopping, the full Thai MyShop guide, and Image hosting.
Configuration
Single-OA mode (default — for most users)
That's the Step 2 snippet above. One environment variable, one OA. Suitable for individual creators, course makers, and most SMB owners.
Multi-OA mode (for agencies)
If you manage several LINE OAs (your own plus client accounts), create a JSON config file at ~/.line-mcp/config.json — the server auto-discovers it, so there's nothing to clone or build:
mkdir -p ~/.line-mcp
nano ~/.line-mcp/config.json # or: code ~/.line-mcp/config.json📘 Full walkthrough (two placement options + security notes) in
docs/multi-oa-setup-th.md. A ready-to-edit template lives inconfig.example.json.
Fill in one entry per OA:
{
"default_oa": "main",
"oas": {
"main": {
"channel_access_token": "TOKEN_1",
"display_name": "Main OA",
"region": "TH",
"myshop_api_key": "MYSHOP_KEY_1"
},
"client_a": {
"channel_access_token": "TOKEN_2",
"display_name": "Client A — Bangkok Cafe"
}
}
}🛍️ LINE Shopping (v2.0): add
"myshop_api_key"to any OA to enable the 14 shopping tools for it (get it fromoaplus.line.biz→ Settings → API keys, Admin role). In single-OA mode, set the env varLINE_MYSHOP_API_KEYinstead. OAs without a key simply keep the messaging tools — the shopping tools never appear and never error.
Then drop the LINE_CHANNEL_ACCESS_TOKEN env var from your MCP config — the server discovers ~/.line-mcp/config.json automatically.
Resolution order:
LINE_MCP_CONFIGenv var (custom path)~/.line-mcp/config.jsonLINE_CHANNEL_ACCESS_TOKENenv var (single-OA fallback)
Switching the active OA at runtime
Ask your AI host:
"Switch to client_a"
→ line_use_oa({ oa_id: "client_a" })Or override per-call with the oa parameter on any tool.
Advanced — HTTP transport (self-hosted)
For agencies running a shared remote instance, the server also supports Streamable HTTP. See docs/http-transport.md.
🖼️ Image hosting
Every tool that uses an image — broadcast image, rich menu, card, imagemap, flex, and LINE Shopping products (v2.0) — needs a public, direct HTTPS URL to a JPEG/PNG. LINE fetches the image from that URL, so it must be directly accessible (not a preview page). MyShop has no binary upload endpoint, so host the image first and pass its URL.
✅ Recommended: Cloudflare R2, AWS S3 (public bucket),
raw.githubusercontent.com, Cloudinary, ImageKit — stable, direct URLs.⚠️ Avoid: Google Drive / Dropbox share links — they return an HTML preview page, not a direct image, so LINE can't read them reliably.
Documentation
Doc | What's in it |
Thai-language quick start (5-minute walkthrough) | |
📨 Messaging full guide — Thai. All 34 tools explained, transports & send modes, real workflows, safety limits, and troubleshooting | |
🛍️ LINE Shopping (MyShop) full guide — Thai. Get the API key, all 14 tools explained, real end-to-end workflows, safety rules, and troubleshooting | |
Per-host MCP setup — Cowork / Claude Desktop / Cursor / Codex (Thai) | |
Multi-OA configuration guide (Thai) | |
Test a local build in Claude Cowork before publishing (Thai) | |
Streamable HTTP transport for self-hosted / remote use | |
Runnable examples |
Versioning
This project follows Semantic Versioning. Current release: v2.0.0.
Latest changes (v2.0.0): +14 LINE Shopping tools via the MyShop Open API — products, inventory, orders (incl. parcel labels), settlements, and checkout links. API-key only, no webhook/server, fully opt-in (registers only when a MyShop key is set) and non-breaking on the 34 messaging tools. See RELEASE_NOTES_v2.0.0.md.
Previously (v1.1.0): +10 tools completing LINE's token-only Messaging API surface (rich-menu lifecycle, Rich/Card message builders, audience update, webhook set/get, narrowcast progress, token check). See RELEASE_NOTES_v1.1.0.md.
Roadmap
v1.x — Full token-only Messaging API coverage: outbound + rich-menu lifecycle + Rich/Card message builders + audiences + insights + coupons.
v2.0 — ✅ LINE Shopping (MyShop Open API) shipped — products, inventory, orders, parcel labels, settlements, and checkout links (API-key only, no webhook). See RELEASE_NOTES_v2.0.0.md.
Future direction is guided by real-world usage and community feedback.
Contributing
PRs are welcome. Please open an issue first to discuss substantial changes.
When contributing:
Tool names:
line_{action}_{resource}(snake_case, prefixline_).Tool descriptions: English (for LLMs) — Thai examples encouraged.
User-facing strings: Thai-friendly (centralized in
src/i18n/th.ts).Pre-flight validation on every send tool.
Quota Guardian + Quiet Hours on every consumption tool.
Author
Dr. Wasin Treesinthuros (พี่โต / Dr. Wasin / #จารโต)
CEO at Innovation Vantage
Founder at ForgeAI — AI Transformation Studio
LINE Certified Coach 2026
AI Transformation educator, SaaS builder, university lecturer
This project is part of a broader mission to bring production-grade AI automation to every Thai practitioner — regardless of technical background.
GitHub: @wasintoh
License
MIT © Dr. Wasin Treesinthuros — Innovation Vantage / ForgeAI
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/wasintoh/line-oa-mcp-ultimate'
If you have feedback or need assistance with the MCP directory API, please join our Discord server