@bautran1911/n8n-nodes-zalo-oa
v1.0.14
Published
n8n community node tích hợp Zalo Official Account (Zalo OA) – gửi ZBS Template Message qua số điện thoại và tự động quản lý Access Token.
Downloads
1,253
Maintainers
Readme
@bautran1911/n8n-nodes-zalo-oa
n8n community node tích hợp Zalo Official Account (Zalo OA) vào workflow n8n — hỗ trợ Webhook Trigger nhận tin nhắn từ người dùng, gửi tin tư vấn (CS Message) để tự động phản hồi chatbot AI, gửi ZBS Template Message qua số điện thoại và tự động quản lý Access Token.
Mục lục
- Giới thiệu
- Cài đặt
- Cấu hình Credential
- Lấy Access Token và Refresh Token từ Zalo
- Zalo OA Trigger (Webhook)
- Workflow chatbot AI với Zalo OA
- Operations
- Ví dụ sử dụng
- Compatibility
- Tài nguyên
- Tác giả
- ☕ Ủng hộ tác giả
Giới thiệu
Zalo OA là Trang Zalo Official Account — nền tảng nhắn tin của Zalo dành cho doanh nghiệp. Package này cung cấp 2 node:
- Zalo OA (action node) — gọi các API của Zalo OpenAPI / Zalo Business Solution (ZBS).
- Zalo OA Trigger (webhook trigger) — nhận sự kiện webhook từ Zalo OA để khởi động workflow (chatbot AI, auto-reply, phân loại tin nhắn...).
Tính năng chính:
- ⚡ Webhook Trigger: Nhận realtime các sự kiện
user_send_text/image/link/audio/video/sticker/location/file/gif,follow,unfollow,user_submit_info,user_seen_message,... Có xác thực chữ kýX-ZEvent-Signaturevà lọc event theo ý. - 💬 Gửi Tin Tư Vấn (CS Message): Gửi tin nhắn văn bản tự do tới user đã tương tác với OA trong vòng 7 ngày (dùng cho chatbot AI phản hồi).
- 📨 ZBS Template Message: Gửi tin mẫu đã duyệt qua số điện thoại.
- 👤 Quản lý Người Dùng: Truy xuất danh sách người quan tâm, chi tiết người dùng.
- 💭 Quản lý Hội Thoại: Đọc lịch sử tin nhắn đã trao đổi với khách hàng.
- 🏢 Thông Tin OA: Lấy profile Zalo Official Account.
- 🔄 Tự động Refresh Access Token khi hết hạn và ghi đè vào n8n credential.
- 🔐 Auto-retry khi hết hạn token (áp dụng cho các mã lỗi
-124,3,-216,-220).
Cài đặt
Trong n8n (khuyên dùng)
- Vào Settings → Community Nodes
- Nhấn Install
- Nhập
@bautran1911/n8n-nodes-zalo-oa - Nhấn Install và khởi động lại n8n
Thủ công (self-hosted)
npm install @bautran1911/n8n-nodes-zalo-oaCấu hình Credential
Sau khi cài node, tạo credential Zalo OA API với các thông tin sau:
| Trường | Mô tả |
|--------|-------|
| Credential Name | Tên phân biệt credential này (ví dụ: Zalo OA - Shop Thời Trang) |
| App ID | Lấy tại developers.zalo.me → App của bạn → App ID |
| Secret Key | Lấy tại developers.zalo.me → App của bạn → Secret Key |
| Access Token | Xem hướng dẫn bên dưới |
| Refresh Token | Xem hướng dẫn bên dưới |
| n8n Instance URL | URL n8n của bạn, ví dụ: http://localhost:5678 hoặc https://n8n.example.com |
| n8n API Key | Tạo tại n8n → Settings → API → Create an API key |
| Credential ID | Sau khi lưu credential, xem ID trên URL trình duyệt: .../credentials/<ID> |
Lấy Access Token và Refresh Token từ Zalo
Zalo sử dụng OAuth2 kết hợp PKCE để cấp quyền. Có 2 cách lấy token:
📌 Thuật ngữ quan trọng:
- Access Token: Có hiệu lực 25 giờ. Dùng để gọi API.
- Refresh Token: Có hiệu lực 3 tháng. Chỉ dùng 1 lần để lấy Access Token mới (và sẽ nhận Refresh Token mới).
- Authorization Code: Chỉ dùng 1 lần, hết hạn sau 10 phút.
Cách 2: Sử dụng API Explorer (Khuyên dùng)
💡 Phù hợp cho: Admin của OA hoặc Admin của Ứng dụng muốn lấy token nhanh mà không cần cấu hình server.
Các bước thực hiện:
Truy cập Zalo API Explorer (Vào Zalo for Developers → Công cụ & Hỗ trợ → API Explorer)

Tại màn hình API Explorer, chọn Ứng dụng của bạn

Tại mục Loại access token, chọn OA Access Token

Chọn Official Account (OA) mà bạn muốn liên kết và cấp quyền

Hệ thống hiển thị trang yêu cầu cấp quyền → kiểm tra các quyền → nhấn Cho phép

Sau khi nhấn "Cho phép", công cụ hiển thị:
- Access Token → nhấn biểu tượng 📋 Copy để lấy
- Refresh Token → nhấn biểu tượng 📋 Copy để lưu lại

Dán Access Token và Refresh Token vào tương ứng trong credential n8n

⚠️ Lưu ý: Access Token từ API Explorer hết hạn sau 25 giờ. Node sẽ tự động dùng Refresh Token để gia hạn khi phát hiện lỗi hết hạn (mã lỗi
-124hoặc3).
Cách 1: Sử dụng OAuth v4 (Tích hợp hệ thống)
💡 Phù hợp cho: Tích hợp tự động, cần lấy token theo dạng programmatic.
Bước 1 — Tạo App trên Zalo Developer
- Đăng nhập tại developers.zalo.me
- Tạo ứng dụng mới → lấy App ID và Secret Key
- Vào mục Official Account → Liên kết OA → liên kết OA của bạn với App
- Thiết lập Callback URL trong phần cài đặt ứng dụng
Bước 2 — Tạo Code Verifier & Code Challenge (PKCE)
# Tạo code_verifier (chuỗi ngẫu nhiên)
code_verifier=$(openssl rand -base64 64 | tr -d '=+/' | cut -c1-64)
# Tạo code_challenge (SHA-256 + Base64 không padding)
code_challenge=$(echo -n "$code_verifier" | openssl sha256 -binary | base64 | tr '+/' '-_' | tr -d '=')Bước 3 — Lấy Authorization Code
Gửi URL sau cho Admin OA để họ nhấn "Cho phép":
https://oauth.zaloapp.com/v4/oa/permission?app_id=YOUR_APP_ID&redirect_uri=YOUR_CALLBACK_URL&code_challenge=YOUR_CODE_CHALLENGEZalo sẽ redirect về Callback URL kèm mã code:
https://your-callback.com/callback?code=AUTHORIZATION_CODEBước 4 — Đổi Code lấy Tokens
curl -X POST https://oauth.zaloapp.com/v4/oa/access_token \
-H "Content-Type: application/x-www-form-urlencoded" \
-H "secret_key: YOUR_SECRET_KEY" \
-d "app_id=YOUR_APP_ID&code=AUTHORIZATION_CODE&grant_type=authorization_code&code_verifier=YOUR_CODE_VERIFIER"Response:
{
"access_token": "...",
"refresh_token": "...",
"expires_in": 90000
}Copy access_token và refresh_token vào credential n8n.
Gia hạn Token bằng Refresh Token
curl -X POST https://oauth.zaloapp.com/v4/oa/access_token \
-H "Content-Type: application/x-www-form-urlencoded" \
-H "secret_key: YOUR_SECRET_KEY" \
-d "app_id=YOUR_APP_ID&refresh_token=YOUR_REFRESH_TOKEN&grant_type=refresh_token"✅ Node n8n đã tích hợp sẵn tính năng tự động gia hạn token — bạn không cần chạy lệnh trên thủ công. Xem phần Operations → Refresh Token.
Zalo OA Trigger (Webhook)
Node Zalo OA Trigger nhận webhook realtime từ Zalo Official Account. Cổng ra (Main) truyền dữ liệu sang bất kỳ node nào khác (AI Agent, IF, Switch, Code, Set...) để xử lý và phản hồi.
Cấu hình webhook trên Zalo OA
- Kéo node Zalo OA Trigger vào workflow → copy Production URL.
- Vào Zalo OA Management → chọn OA → Quản lý ứng dụng → Cấu hình Webhook → dán URL vào và chọn các sự kiện cần nhận.
- Quay lại n8n, mở node, chọn Events muốn lọc (hoặc
All User Send Eventsđể nhận mọi loại tin user gửi).
Tham số
| Tham số | Mô tả |
|---------|-------|
| Events | Lọc theo event_name. Option đặc biệt All User Send Events gộp toàn bộ user_send_*. Để rỗng sẽ nhận mọi event. |
| Ignore OA Echo | Bỏ qua event oa_send_* (và các event có sender.id == recipient.id) để tránh vòng lặp khi node Zalo OA tự phát sinh event. |
| Verify Signature | Xác thực header X-ZEvent-Signature dùng secret_key trong credential. So khớp SHA256(rawBody + timestamp + secretKey) và fallback HMAC-SHA256(rawBody, secretKey). |
| Simplify | Trả output dạng rút gọn với các field phẳng tiện cho AI (xem bên dưới) thay vì raw body. |
Cấu trúc output (Simplify = ON)
{
"event_name": "user_send_text",
"app_id": "1234567890",
"sender_id": "6123456789",
"recipient_id": "1234567890",
"user_id_by_app": "",
"timestamp": "1713456789000",
"user_id": "6123456789",
"text": "Shop ơi cho em hỏi giá...",
"msg_id": "abc-xyz",
"attachments": [],
"message": { "text": "...", "msg_id": "...", "attachments": [] },
"raw": { "...": "toàn bộ body gốc" }
}🤖 Các field tiện lợi:
user_id(tự chọnsender.idhoặcrecipient.idtùy event),text,msg_id,attachments— dùng trực tiếp làm input cho AI Agent / LLM và đầu vào cho nodeZalo OAresource Tin Tư Vấn để phản hồi khách hàng.
Workflow chatbot AI với Zalo OA
[Zalo OA Trigger]
│ user_id, text
▼
[AI Agent / LLM] (prompt = "Bạn là nhân viên CSKH... Khách hỏi: {{$json.text}}")
│ output = câu trả lời
▼
[Zalo OA] Resource = Tin Tư Vấn → Operation = Gửi Tin Tư Vấn Dạng Văn Bản
User ID = {{ $('Zalo OA Trigger').item.json.user_id }}
Nội dung = {{ $json.output }}Mẹo:
- Bật Ignore OA Echo trên trigger để không bị kích hoạt lại bởi
oa_send_textsau khi bạn gửi reply. - Chọn Events = User Send Text để không bị trigger bởi follow/seen/received.
- Dùng node Code để cắt
text≤ 500 ký tự và/hoặc enrich thêm context (intent, session data, lịch sử từ Redis/Postgres) trước khi vào AI Agent. - Dùng
$('Zalo OA Trigger').item.json.user_idở node sau cùng để giữ đúnguser_idgốc, không bị mất qua các bước trung gian.
Operations
Resource: Thông Tin OA
- Lấy Thông Tin OA: Truy xuất profile chung của Zalo OA (OA ID, Tên, Avatar, Cover, Số người quan tâm, Tình trạng xác thực...).
Resource: Hội Thoại (Conversation)
- Lấy Chi Tiết Hội Thoại: Lấy lịch sử và nội dung tin nhắn trao đổi giữa Zalo OA và Khách hàng (yêu cầu
User ID). Cho phép phân trang thông quaOffsetvàCount(tối đa 10 tin/lần).
Resource: Người Dùng (OA)
- Truy Xuất Chi Tiết Người Dùng: Nhận thông tin đầy đủ về một người dùng (tên, ảnh, trạng thái theo dõi, thiết lập riêng...) theo
User ID. - Truy Xuất Danh Sách Người Dùng: Thiết lập lấy danh sách kèm bộ lọc đa dạng (Offset, Count, Tag ID, Tương tác gần nhất TODAY/L7D/L30D, Is Follower).
Resource: Tin Tư Vấn (CS Message)
Gửi Tin Tư Vấn Dạng Văn Bản — gửi tin nhắn văn bản tới một người dùng cụ thể thông qua user_id. Dùng cho workflow chatbot AI phản hồi lại tin nhắn khách gửi vào OA.
| Tham số | Bắt buộc | Mô tả |
|---------|----------|-------|
| User ID | ✅ | Zalo User ID của người nhận — lấy trực tiếp từ output user_id của Zalo OA Trigger |
| Nội Dung Văn Bản | ✅ | Nội dung tin nhắn văn bản (tối đa 500 ký tự theo Zalo) |
⚠️ Điều kiện Zalo: chỉ gửi được tới user đã tương tác với OA trong 7 ngày gần nhất. API endpoint:
POST https://openapi.zalo.me/v3.0/oa/message/cs— xem tài liệu Zalo.
Resource: Tin Nhắn ZBS Template
Gửi ZBS Template Message qua số điện thoại người nhận.
| Tham số | Bắt buộc | Mô tả |
|---------|----------|-------|
| Số Điện Thoại Người Nhận | ✅ | Định dạng quốc tế, ví dụ: 84987654321 |
| Template ID | ✅ | ID template đã được phê duyệt trên Zalo OA |
| Dữ Liệu Template (JSON) | ✅ | Object JSON chứa các biến của template |
| Tracking ID | ❌ | Mã theo dõi tuỳ chỉnh (tối đa 48 ký tự) |
| Chế Độ Gửi | ❌ | Gửi Thường (trong hạn mức) hoặc Gửi Vượt Hạn Mức |
Resource: Token
Refresh Token — Làm mới Access Token từ Refresh Token và tự động ghi đè vào credential.
Sử dụng khi muốn chủ động làm mới token (ví dụ: chạy định kỳ mỗi 5 ngày).
⚠️ Lưu ý: Giới hạn tốc độ gọi API (Rate Limit)
Zalo OA áp dụng các giới hạn tốc độ gọi API (Rate Limit) riêng nhằm duy trì ổn định hệ thống. Việc gọi API với tần suất quá cao (ví dụ: chạy qua Loop/Split in Batches tốc độ cao trong n8n) có thể làm ứng dụng vượt mức cho phép, kết quả là bạn sẽ nhận cảnh báo lỗi (Mã lỗi thông thường là -32).
- Gửi tin nhắn: Bị giới hạn tương ứng với loại OA và quỹ tin nhắn.
- Truy xuất thông tin người dùng/Hội thoại: Mức giới hạn quy định số request được phép trong 1 giây/phút/ngày.
👉 Tham khảo chi tiết các hạn mức: Giới hạn tốc độ gọi API (Zalo for Developers)
💡 Mẹo khi dùng n8n:
- Nếu bạn xử lý hàng loạt người dùng/tin nhắn, hãy tích hợp thêm node Wait (hoặc cấu hình Batches) để tạo độ trễ (delay) hợp lý giữa các lần gọi API, tránh rủi ro bị chặn bởi Zalo.
Ví dụ sử dụng
Gửi thông báo đặt hàng thành công
Template Data:
{
"customer_name": "Nguyễn Văn A",
"order_id": "DH-2024-001",
"total_amount": "500.000đ",
"delivery_date": "10/04/2024"
}Cấu hình node:
- Số Điện Thoại:
84987654321 - Template ID:
123456 - Dữ Liệu Template: JSON ở trên
Tự động refresh token mỗi 5 ngày
Tạo workflow với:
- Schedule Trigger → mỗi 5 ngày lúc 3:00 sáng
- Zalo OA node → Resource:
Token→ Operation:Refresh Token
Compatibility
| Phiên bản | Trạng thái | |-----------|-----------| | n8n ≥ 1.0.0 | ✅ Tương thích | | Node.js ≥ 22 | ✅ Tương thích |
Tài nguyên
- Tài liệu Zalo ZBS API
- Zalo OA API Reference
- Zalo OA Webhook — Sự kiện người dùng gửi tin nhắn
- Zalo OA — Gửi tin tư vấn dạng văn bản
- n8n Community Nodes Docs
- GitHub Repository
Tác giả
Báu Đẹp Trai
📧 [email protected]
🐙 github.com/bautran1911
☕ Ủng hộ tác giả
Nếu node này giúp ích cho công việc của bạn, hãy ủng hộ tác giả một ly cà phê để tiếp tục phát triển và duy trì dự án! 🙏
🏦 Chuyển khoản ngân hàng (Việt Nam)
| Thông tin | Chi tiết |
|-----------|----------|
| Ngân hàng | MB Bank (Ngân Hàng Quân Đội) |
| Số tài khoản | 0930113997979 |
| Chủ tài khoản | TRAN NGOC BAU |
| Nội dung CK | donate n8n zalo oa |
📱 Quét QR để chuyển khoản nhanh
💡 Bạn cũng có thể dùng MoMo, ZaloPay, hoặc VietQR để chuyển khoản nhanh qua số tài khoản trên.
Version History
v1.0.14 (2026-04)
- ⚡ NEW: Thêm node Zalo OA Trigger — webhook trigger nhận event realtime từ Zalo OA (user_send_text/image/link/audio/video/sticker/location/file/gif, follow, unfollow, user_submit_info, user_seen_message...).
- 🤖 NEW: Thêm resource Tin Tư Vấn (CS Message) với operation Gửi Tin Tư Vấn Dạng Văn Bản (
POST /v3.0/oa/message/cs) — phục vụ workflow chatbot AI phản hồi tin nhắn khách hàng. - 🔐 Hỗ trợ xác thực chữ ký webhook
X-ZEvent-Signaturetrên trigger. - 🧩 Output rút gọn của trigger trả sẵn
user_id,text,msg_id,attachmentsở top-level để AI Agent / LLM dùng trực tiếp.
v1.0.13 (2026-04)
- 🚀 Thêm API: Lấy thông tin Zalo Official Account
- 🚀 Thêm API: Lấy danh sách người dùng & chi tiết người dùng
- 🚀 Thêm API: Lấy thông tin tin nhắn trong một hội thoại
- 🔄 Bổ sung hỗ trợ tự động Refresh Token với các mã lỗi
-216,-220(bên cạnh-124,3) - ⚠️ Cập nhật cảnh báo Giới hạn tốc độ gọi API (Rate Limit) cho n8n workflow
v1.0.9 (2026-04)
- 🎉 Ra mắt lần đầu
- ✅ Gửi ZBS Template Message qua số điện thoại
- ✅ Tự động Refresh Access Token khi hết hạn
- ✅ Ghi đè token mới vào n8n credential qua REST API
