Trạng thái: sẵn sàng cho DM + spaces qua Google Chat API webhooks (chỉ HTTP).Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Thiết lập nhanh (người mới bắt đầu)
- Tạo một dự án Google Cloud và bật Google Chat API.
- Đi tới: Thông tin xác thực Google Chat API
- Bật API nếu API chưa được bật.
- Tạo một Service Account:
- Nhấn Create Credentials > Service Account.
- Đặt tên tùy ý (ví dụ:
openclaw-chat). - Để trống quyền (nhấn Continue).
- Để trống principal có quyền truy cập (nhấn Done).
- Tạo và tải xuống JSON Key:
- Trong danh sách service account, nhấp vào tài khoản bạn vừa tạo.
- Đi tới thẻ Keys.
- Nhấp Add Key > Create new key.
- Chọn JSON và nhấn Create.
- Lưu tệp JSON đã tải xuống trên máy chủ gateway của bạn (ví dụ:
~/.openclaw/googlechat-service-account.json). - Tạo một ứng dụng Google Chat trong Cấu hình Chat của Google Cloud Console:
- Điền Application info:
- App name: (ví dụ:
OpenClaw) - Avatar URL: (ví dụ:
https://openclaw.ai/logo.png) - Description: (ví dụ:
Personal AI Assistant)
- App name: (ví dụ:
- Bật Interactive features.
- Trong Functionality, chọn Join spaces and group conversations.
- Trong Connection settings, chọn HTTP endpoint URL.
- Trong Triggers, chọn Use a common HTTP endpoint URL for all triggers và đặt thành URL công khai của Gateway, theo sau là
/googlechat.- Mẹo: Chạy
openclaw statusđể tìm URL công khai của Gateway.
- Mẹo: Chạy
- Trong Visibility, chọn Make this Chat app available to specific people and groups in
<Your Domain>. - Nhập địa chỉ email của bạn (ví dụ:
user@example.com) vào hộp văn bản. - Nhấp Save ở phía dưới.
- Điền Application info:
- Bật trạng thái ứng dụng:
- Sau khi lưu, làm mới trang.
- Tìm phần App status (thường ở gần đầu hoặc cuối sau khi lưu).
- Đổi trạng thái thành Live - available to users.
- Nhấp lại Save.
- Cấu hình OpenClaw bằng đường dẫn service account + đối tượng webhook:
- Env:
GOOGLE_CHAT_SERVICE_ACCOUNT_FILE=/path/to/service-account.json - Hoặc cấu hình:
channels.googlechat.serviceAccountFile: "/path/to/service-account.json".
- Env:
- Đặt loại + giá trị đối tượng webhook (khớp với cấu hình ứng dụng Chat của bạn).
- Khởi động Gateway. Google Chat sẽ POST tới đường dẫn webhook của bạn.
Thêm vào Google Chat
Sau khi Gateway đang chạy và email của bạn đã được thêm vào danh sách hiển thị:- Đi tới Google Chat.
- Nhấp biểu tượng + (dấu cộng) bên cạnh Direct Messages.
- Trong thanh tìm kiếm (nơi bạn thường thêm người), nhập App name mà bạn đã cấu hình trong Google Cloud Console.
- Lưu ý: Bot sẽ không xuất hiện trong danh sách duyệt “Marketplace” vì đây là ứng dụng riêng tư. Bạn phải tìm kiếm bot theo tên.
- Chọn bot của bạn từ kết quả.
- Nhấp Add hoặc Chat để bắt đầu cuộc trò chuyện 1:1.
- Gửi “Hello” để kích hoạt trợ lý!
URL công khai (chỉ Webhook)
Google Chat webhooks yêu cầu endpoint HTTPS công khai. Để bảo mật, chỉ đưa đường dẫn/googlechat ra internet. Giữ bảng điều khiển OpenClaw và các endpoint nhạy cảm khác trong mạng riêng của bạn.
Tùy chọn A: Tailscale Funnel (Khuyến nghị)
Dùng Tailscale Serve cho bảng điều khiển riêng tư và Funnel cho đường dẫn webhook công khai. Cách này giữ/ ở chế độ riêng tư, đồng thời chỉ công khai /googlechat.
-
Kiểm tra Gateway của bạn đang bind vào địa chỉ nào:
Ghi lại địa chỉ IP (ví dụ:
127.0.0.1,0.0.0.0, hoặc IP Tailscale của bạn như100.x.x.x). -
Chỉ đưa bảng điều khiển ra tailnet (cổng 8443):
-
Chỉ công khai đường dẫn webhook:
- Ủy quyền Node cho quyền truy cập Funnel: Nếu được nhắc, hãy truy cập URL ủy quyền hiển thị trong đầu ra để bật Funnel cho Node này trong chính sách tailnet của bạn.
-
Xác minh cấu hình:
https://<node-name>.<tailnet>.ts.net/googlechat
Bảng điều khiển riêng tư của bạn vẫn chỉ truy cập được trong tailnet:
https://<node-name>.<tailnet>.ts.net:8443/
Dùng URL công khai (không có :8443) trong cấu hình ứng dụng Google Chat.
Lưu ý: Cấu hình này vẫn tồn tại sau khi khởi động lại. Để xóa sau này, chạytailscale funnel resetvàtailscale serve reset.
Tùy chọn B: Reverse Proxy (Caddy)
Nếu bạn dùng reverse proxy như Caddy, chỉ proxy đường dẫn cụ thể:your-domain.com/ sẽ bị bỏ qua hoặc trả về 404, trong khi your-domain.com/googlechat được định tuyến an toàn tới OpenClaw.
Tùy chọn C: Cloudflare Tunnel
Cấu hình quy tắc ingress của tunnel để chỉ định tuyến đường dẫn webhook:- Đường dẫn:
/googlechat->http://localhost:18789/googlechat - Quy tắc mặc định: HTTP 404 (Không tìm thấy)
Cách hoạt động
- Google Chat gửi webhook POST tới Gateway. Mỗi yêu cầu bao gồm header
Authorization: Bearer <token>.- OpenClaw xác minh bearer auth trước khi đọc/phân tích toàn bộ body webhook khi có header.
- Các yêu cầu Google Workspace Add-on có
authorizationEventObject.systemIdTokentrong body được hỗ trợ thông qua ngân sách body pre-auth chặt chẽ hơn.
- OpenClaw xác minh token theo
audienceType+audienceđã cấu hình:audienceType: "app-url"→ audience là URL webhook HTTPS của bạn.audienceType: "project-number"→ audience là số dự án Cloud.
- Tin nhắn được định tuyến theo space:
- DM dùng khóa phiên
agent:<agentId>:googlechat:direct:<spaceId>. - Spaces dùng khóa phiên
agent:<agentId>:googlechat:group:<spaceId>.
- DM dùng khóa phiên
- Quyền truy cập DM mặc định là ghép đôi. Người gửi không xác định sẽ nhận mã ghép đôi; phê duyệt bằng:
openclaw pairing approve googlechat <code>
- Group spaces mặc định yêu cầu @-mention. Dùng
botUsernếu phát hiện mention cần tên người dùng của ứng dụng.
Mục tiêu
Dùng các định danh này cho việc gửi và allowlist:- Tin nhắn trực tiếp:
users/<userId>(khuyến nghị). - Email thô
name@example.comcó thể thay đổi và chỉ được dùng để khớp allowlist trực tiếp khichannels.googlechat.dangerouslyAllowNameMatching: true. - Đã ngừng dùng:
users/<email>được xem là id người dùng, không phải allowlist email. - Spaces:
spaces/<spaceId>.
Điểm nổi bật về cấu hình
- Thông tin xác thực service account cũng có thể được truyền nội tuyến bằng
serviceAccount(chuỗi JSON). serviceAccountRefcũng được hỗ trợ (env/file SecretRef), bao gồm các ref theo từng tài khoản trongchannels.googlechat.accounts.<id>.serviceAccountRef.- Đường dẫn webhook mặc định là
/googlechatnếu chưa đặtwebhookPath. dangerouslyAllowNameMatchingbật lại khớp principal email có thể thay đổi cho allowlist (chế độ tương thích break-glass).- Reaction có sẵn qua công cụ
reactionsvàchannels actionkhi bậtactions.reactions. - Hành động tin nhắn cung cấp
sendcho văn bản vàupload-filecho gửi tệp đính kèm rõ ràng.upload-filechấp nhậnmedia/filePath/pathcùng vớimessage,filename, và mục tiêu thread tùy chọn. typingIndicatorhỗ trợnone,message(mặc định), vàreaction(reaction yêu cầu OAuth người dùng).- Tệp đính kèm được tải xuống qua Chat API và lưu trong pipeline phương tiện (kích thước giới hạn bởi
mediaMaxMb).
Khắc phục sự cố
405 Method Not Allowed
Nếu Google Cloud Logs Explorer hiển thị lỗi như:-
Chưa cấu hình kênh: Thiếu phần
channels.googlechattrong cấu hình của bạn. Xác minh bằng:Nếu trả về “Config path not found”, hãy thêm cấu hình (xem Điểm nổi bật về cấu hình). -
Plugin chưa được bật: Kiểm tra trạng thái Plugin:
Nếu hiển thị “disabled”, thêm
plugins.entries.googlechat.enabled: truevào cấu hình của bạn. -
Gateway chưa được khởi động lại: Sau khi thêm cấu hình, khởi động lại Gateway:
Vấn đề khác
- Kiểm tra
openclaw channels status --probeđể xem lỗi xác thực hoặc thiếu cấu hình audience. - Nếu không có tin nhắn nào đến, xác nhận URL webhook + đăng ký sự kiện của ứng dụng Chat.
- Nếu cổng mention chặn phản hồi, đặt
botUserthành tên tài nguyên người dùng của ứng dụng và xác minhrequireMention. - Dùng
openclaw logs --followtrong khi gửi tin nhắn thử để xem các yêu cầu có tới Gateway hay không.
Liên quan
- Tổng quan về kênh — tất cả các kênh được hỗ trợ
- Ghép đôi — xác thực DM và luồng ghép đôi
- Nhóm — hành vi trò chuyện nhóm và cổng mention
- Định tuyến kênh — định tuyến phiên cho tin nhắn
- Bảo mật — mô hình truy cập và gia cố bảo mật