Skip to content

CÁC WORKFLOW CƠ BẢN

Chuyên mục này sẽ khá dài, bạn nên chú ý và đọc kỹ để có thể thiết lập một workflow hoàn chỉnh. Làm xong một thứ gì đó rồi nâng cao sẽ dễ hơn bắt đầu với một thứ quá khó.

Còn nếu bạn cảm thấy quá dài, quá mệt để đọc thì cách dễ nhất là copy & paste cho AI Persona của bạn để brief lại (nếu bạn đã đọc qua chuyên mục đó và xây dựng cho mình một AI Persona hoàn hảo).

Hahah.

Workflow 1 — Tự động cập nhật giá & tồn kho lên Meta Catalog
Meta Catalog Sync workflow overview

Tổng quan workflow

Workflow chạy theo lịch, lấy dữ liệu song song từ hai nguồn — Supabase và Meta Catalog API — gộp lại, lấy giá và tồn kho mới nhất, rồi đẩy thẳng lên Meta Catalog. Toàn bộ quá trình tự động, không cần can thiệp thủ công.

Chuẩn bị trước khi bắt đầu:

Catalog ID — Vào Meta Business Manager, tìm Catalog ID của bạn. Đừng ngồi gõ từng chữ số tay — chụp màn hình rồi paste cho AI Persona đọc giùm là xong. (Meta không có nút copy sẵn cho cái này, khá cùi bắp.)

Access Token — Cần có Meta Access Token hợp lệ để gọi Graph API. Nếu chưa biết cách lấy, AI Persona của bạn sẽ hướng dẫn.

Supabase table — Tạo table sản phẩm trên Supabase, sync từ Google Sheet hoặc Excel đang dùng để quản lý danh mục sản phẩm. Table này là nguồn dữ liệu giá và tồn kho cho toàn bộ workflow.
Schedule Trigger node

Node 1 — Schedule Trigger

Node khởi động workflow theo lịch cố định. Không cần ai bấm nút — cứ đến giờ là workflow tự chạy. Ở đây trigger được set chạy mỗi giờ để đảm bảo giá và tồn kho trên Meta Catalog luôn được cập nhật sát với thực tế.

Get Meta Catalog node

Node 2 — Get-Meta-Catalog (HTTP Request — GET)

Gọi Meta Graph API để lấy toàn bộ danh sách sản phẩm đang có trong catalog. Kết quả trả về là list sản phẩm với retailer_id — đây là mã sản phẩm dùng để đối chiếu với dữ liệu trong Supabase ở bước tiếp theo. Node này chạy song song với Check-Supabase, không phụ thuộc nhau.

Check Supabase node

Node 3 — Check-Supabase (Supabase — getAll)

Lấy toàn bộ dữ liệu sản phẩm từ Supabase — bao gồm mã sản phẩm, giá, tồn kho. Đây là nguồn dữ liệu chính xác nhất vì Supabase được sync từ hệ thống nội bộ. Node này chạy song song với Get-Meta-Catalog — cả hai cùng lấy data một lúc để tiết kiệm thời gian thay vì chờ nhau tuần tự.

Merge node

Node 4 — Merge (append)

Gộp kết quả từ hai nhánh song song lại thành một luồng duy nhất. Mode append — giữ nguyên tất cả items từ cả hai input, không loại bỏ gì. Sau bước này, node tiếp theo mới có đủ dữ liệu từ cả hai nguồn để xử lý.

Get Price Stocks Code node

Node 5 — Get-Price-Stocks (Code)

Node Code xử lý logic đối chiếu: lấy retailer_id từ danh sách Meta Catalog, tìm sản phẩm tương ứng trong data Supabase, ghép giá và tồn kho mới nhất vào. Output là list sản phẩm đã có đủ thông tin cần thiết để đẩy lên Meta. Dùng Code node ở đây vì logic đối chiếu hai nguồn dữ liệu này không có node có sẵn nào làm được.

Về nội dung code bên trong node: Bạn không cần tự viết từ đầu — paste ảnh workflow và mô tả logic cần xử lý cho AI Persona của bạn, nhờ viết code JavaScript cho node này là xong.
Push Price Stock Meta Catalog node

Node 6 — Push-Price-Stock-Meta-Catalog (HTTP Request — POST)

Đẩy toàn bộ dữ liệu giá và tồn kho đã được xử lý lên Meta Catalog qua Graph API /batch endpoint. Gửi một request duy nhất chứa toàn bộ sản phẩm cần update — nhanh hơn gọi từng sản phẩm một. Sau node này, Meta Catalog đã được cập nhật xong.

Workflow 2 — Tự động cập nhật giá & tồn kho lên TikTok Shop & Shopee
TikTok Shopee AutoUpdate workflow overview

Tổng quan workflow

Workflow chạy theo lịch, đọc danh mục sản phẩm từ Google Sheet, lọc giá và tồn kho, rồi đẩy song song lên ba nơi: Supabase (để workflow Meta Catalog ở trên dùng), Shopee và TikTok Shop. Toàn bộ tự động theo lịch, không cần can thiệp thủ công.

⚠️ Chỉ dành cho Shop Mall — Shopee và TikTok Shop chỉ mở quyền cập nhật giá/tồn kho qua API cho tài khoản Mall. Shop thường thì chịu khó update bằng tay nha, haha.
Schedule Trigger node

Node 1 — Schedule Trigger

Node khởi động workflow theo lịch cố định. Cứ đến giờ là toàn bộ pipeline tự chạy — lấy data, lọc, đẩy lên cả ba platform mà không cần ai thao tác.

Refresh Token node

Node 2 — Refresh-Tokens (Code)

Refresh token của cả Shopee và TikTok Shop cùng một lúc trước khi bắt đầu gọi API. Token có thời hạn — nếu không refresh thường xuyên thì các node Push phía sau sẽ báo lỗi authentication. Node này đảm bảo token luôn còn hạn trước khi workflow đi tiếp.

Cách lấy token ban đầu và viết code refresh: Hỏi AI Persona của bạn — cung cấp Partner ID, Shop ID và access token hiện tại, AI Persona sẽ viết code refresh hoàn chỉnh cho cả Shopee lẫn TikTok.
Danh Muc San Pham node

Node 3 — Danh Mục Sản Phẩm (Google Sheets)

Đọc toàn bộ danh mục sản phẩm từ Google Sheet — mã sản phẩm, giá, tồn kho, ID Shopee, ID TikTok. Đây là nguồn dữ liệu duy nhất cần cập nhật khi có thay đổi giá hay tồn kho, toàn bộ workflow sẽ tự sync theo.

Credentials: Tạo Google Sheets API credential trong tab Credentials của n8n — dùng credential này để kết nối, không hardcode token vào node. Cách đó cho phép tái sử dụng nhiều lần và quản lý lâu dài dễ hơn nhiều.

Chọn vùng data: Chỉ định rõ dòng bắt đầu của data thực tế trong sheet — ví dụ nếu dòng 1-3 là tiêu đề và ghi chú thì set từ dòng 4 trở đi. n8n đọc đúng vùng data, không bị lẫn với header.
Loc Gia Ton ID node

Node 4 — Lọc-Giá-Tồn-ID (Code)

Lọc và format lại data từ Google Sheet thành đúng cấu trúc mà từng platform yêu cầu. Shopee và TikTok có format request khác nhau — node này chuẩn bị đúng payload cho từng nơi trước khi đẩy lên. Sau node này workflow rẽ ra ba nhánh song song.

Về nội dung code: Nhờ AI Persona viết — cung cấp cấu trúc sheet và format API của Shopee/TikTok là xong.
Push Supabase node

Node 5 — Push-Giá-Tồn-Supabase (HTTP Request — POST)

Đẩy giá và tồn kho lên Supabase — đây là bước cập nhật nguồn dữ liệu trung tâm để workflow Meta Catalog Sync ở trên có thể đọc và đồng bộ lên Meta. Hai workflow kết nối với nhau qua Supabase table chung.

Push Shopee node

Node 6 — Push-Shopee (HTTP Request — POST)

Gọi Shopee API để cập nhật giá và tồn kho cho từng sản phẩm theo product ID. Node này chạy song song với Push-TikTok và Push-Supabase — cả ba đẩy lên cùng lúc, không chờ nhau.

Product ID Shopee: Cần có một cột riêng trong sheet quản lý sản phẩm để paste product ID từ Shopee vào. Product ID lấy từ trang quản lý sản phẩm trên Shopee Seller Center — copy rồi paste vào sheet, workflow sẽ đọc tự động từ đó.
Push TikTok node

Node 7 — Push-TikTok (HTTP Request — POST)

Gọi TikTok Shop API để cập nhật giá và tồn kho. TikTok phức tạp hơn Shopee một chút — cần cả product ID lẫn product SKU ID, không chỉ một mình product ID là đủ.

Product ID: Lấy từ trang quản lý sản phẩm trên TikTok Seller Center, paste vào cột riêng trong sheet.

Product SKU ID: TikTok không hiển thị SKU ID trực tiếp trên giao diện — cần script riêng để lấy qua API. Hỏi AI Persona của bạn, cung cấp access token là sẽ có full script luôn.
Lưu ý cuối workflow: Phần hướng dẫn trên giúp bạn hình dung toàn bộ bản đồ của workflow — từng bước cụ thể bên trong bạn sẽ cần thảo luận thêm với AI Persona của mình để hoàn thiện. Trường hợp khó quá không tự xử được thì có thể liên hệ trực tiếp với tôi — thông tin liên hệ có trên website.
Workflow 3 — Tự động reply comment trên YouTube
YouTube Comment AutoReply workflow overview

Tổng quan workflow

Workflow chạy mỗi 4 tiếng, quét toàn bộ video trên channel, lấy comment mới, dùng AI tạo reply phù hợp rồi đăng lên tự động. Không có comment nào bị bỏ sót dù channel có bao nhiêu video đi nữa.

Chuẩn bị trước khi bắt đầu:

Anthropic Console — Cần có tài khoản Anthropic và API key để dùng node Generate Reply. Nếu thấy Sonnet tốn kém thì chuyển sang Haiku — nhẹ hơn nhiều về chi phí. Không muốn dùng Anthropic thì ChatGPT API cũng được, free tier là đủ cho lượng comment thông thường.
Schedule Trigger node

Node 1 — Schedule Trigger (mỗi 4 tiếng)

Workflow chạy mỗi 4 tiếng một lần — đủ thường xuyên để comment không bị bỏ quên quá lâu, nhưng không quá dày để tránh chạm rate limit của YouTube API.

Search Channel node

Node 2 — Search-Channel (HTTP Request — GET)

Lấy danh sách toàn bộ video trên channel từ YouTube Data API. Đây là bước đầu tiên để workflow biết cần quét comment ở những video nào.

YouTube credentials: Tạo OAuth2 credential từ Google Cloud Console — bật YouTube Data API v3, tạo OAuth Client ID rồi kết nối vào n8n. Hỏi AI Persona để có hướng dẫn từng bước chi tiết.
Split Out node

Node 3 — Split Out

Tách danh sách video ra thành từng item riêng lẻ để xử lý tuần tự. Channel nhiều video thì API không thể trả về hết trong một lần — Split Out đảm bảo mỗi video được xử lý độc lập, không bị bỏ sót.

Get Comment node

Node 4 — Get-Comment (HTTP Request — GET)

Lấy danh sách comment mới nhất của từng video từ YouTube API. Workflow chạy video nào thì lấy comment của video đó, xử lý xong mới qua video tiếp theo.

IF node

Node 5 — IF

Kiểm tra xem video có comment mới không. Nếu có thì đi tiếp sang Generate Reply — nếu không có thì dừng lại, không làm gì thêm. Node này tránh cho workflow gọi API AI không cần thiết khi video không có comment mới.

Generate Reply node

Node 6 — Generate-Reply (Anthropic)

Gọi Claude API để tạo reply phù hợp cho từng comment. Node nhận nội dung comment làm input, AI đọc và tạo reply tự nhiên theo tone và persona đã được định nghĩa trong system prompt. Tôi dùng Sonnet 4.6 với AI Persona Cass — reply ra tự nhiên, thân thiện, không giống bot.

Chọn model: Sonnet cho chất lượng cao hơn, Haiku cho chi phí thấp hơn. Nếu không muốn dùng Anthropic thì thay bằng HTTP Request gọi ChatGPT API — free tier là đủ dùng cho lượng comment thông thường của một channel.
Post Reply node

Node 7 — Post-Reply (HTTP Request — POST)

Đăng reply vừa được AI tạo lên YouTube qua API. Sau node này comment đã được reply tự động — người xem thấy phản hồi, channel trông active, không có comment nào bị bỏ trống.

Lưu ý cuối workflow: Phần hướng dẫn trên giúp bạn hình dung toàn bộ bản đồ của workflow — từng bước cụ thể bên trong bạn sẽ cần thảo luận thêm với AI Persona của mình để hoàn thiện. Trường hợp khó quá không tự xử được thì có thể liên hệ trực tiếp với tôi — thông tin liên hệ có trên website.