Dịch vụ Chat nâng cao cho phép bạn sử dụng API Google Chat trong Apps Script. API này cho phép tập lệnh tìm, tạo và sửa đổi các không gian Chat, thêm hoặc xoá thành viên khỏi không gian, cũng như đọc hoặc đăng tin nhắn có văn bản, thẻ, tệp đính kèm và biểu tượng cảm xúc.
Điều kiện tiên quyết
- Một ứng dụng Google Chat trong Apps Script được định cấu hình trên trang cấu hình Chat API trong Google Cloud Console. Dự án Apps Script của ứng dụng phải sử dụng một dự án Google Cloud chuẩn thay vì dự án mặc định được tạo tự động cho các dự án Apps Script. Để tạo một ứng dụng Google Chat tương thích, hãy xem bài viết Tạo ứng dụng Google Chat bằng Apps Script.
- Xác thực được định cấu hình cho ứng dụng Chat. Để thay mặt người dùng thực hiện một hành động, bạn phải xác thực người dùng. Để thực hiện một thao tác với tư cách là ứng dụng Chat, bạn cần xác thực ứng dụng bằng tài khoản dịch vụ. Để kiểm tra phương thức xác thực mà API Chat hỗ trợ, hãy xem nội dung Các loại xác thực bắt buộc cho lệnh gọi API Google Chat.
Tài liệu tham khảo
Để biết thêm thông tin về dịch vụ này, hãy xem tài liệu tham khảo về Chat API. Giống như tất cả các dịch vụ nâng cao trong Apps Script, dịch vụ Chat sử dụng các đối tượng, phương thức và tham số giống như API công khai.
Mã mẫu
Các mẫu này cho bạn biết cách thực hiện các thao tác phổ biến trong API Google Chat bằng cách sử dụng dịch vụ nâng cao.
Đăng thông báo có thông tin đăng nhập của người dùng
Ví dụ sau đây minh hoạ cách thay mặt người dùng đăng thông báo vào một không gian Chat.
Thêm phạm vi uỷ quyền
chat.messages.create
vào tệpappsscript.json
của dự án Apps Script:"oauthScopes": [ "https://www.googleapis.com/auth/chat.messages.create" ]
Thêm một hàm như hàm này vào mã của dự án Apps Script:
Đăng thông báo có thông tin xác thực ứng dụng
Ví dụ sau đây minh hoạ cách thay mặt ứng dụng đăng thông báo vào một không gian Chat. Khi sử dụng dịch vụ Chat nâng cao bằng tài khoản dịch vụ, bạn không cần chỉ định phạm vi uỷ quyền trong appsscript.json
. Để biết thông tin chi tiết về việc xác thực bằng tài khoản dịch vụ, hãy xem phần Xác thực dưới dạng ứng dụng Google Chat.
Mua không gian
Ví dụ sau đây minh hoạ cách lấy thông tin về một không gian trò chuyện.
Thêm phạm vi uỷ quyền
chat.spaces.readonly
vào tệpappsscript.json
của dự án Apps Script:"oauthScopes": [ "https://www.googleapis.com/auth/chat.spaces.readonly" ]
Thêm một hàm như hàm này vào mã của dự án Apps Script:
Tạo không gian
Ví dụ sau đây minh hoạ cách tạo không gian Chat.
Thêm phạm vi uỷ quyền
chat.spaces.create
vào tệpappsscript.json
của dự án Apps Script:"oauthScopes": [ "https://www.googleapis.com/auth/chat.spaces.create" ]
Thêm một hàm như hàm này vào mã của dự án Apps Script:
Liệt kê gói thành viên
Ví dụ sau đây minh hoạ cách liệt kê tất cả thành viên của một không gian trò chuyện.
Thêm phạm vi uỷ quyền
chat.memberships.readonly
vào tệpappsscript.json
của dự án Apps Script:"oauthScopes": [ "https://www.googleapis.com/auth/chat.memberships.readonly" ]
Thêm một hàm như hàm này vào mã của dự án Apps Script:
Khắc phục sự cố
Nếu bạn gặp Error 400: invalid_scope
với thông báo lỗi Some requested scopes cannot be shown
, thì tức là bạn chưa chỉ định bất kỳ phạm vi uỷ quyền nào trong tệp appsscript.json
của dự án Apps Script. Trong hầu hết các trường hợp, Apps Script sẽ tự động xác định phạm vi mà tập lệnh cần, nhưng khi sử dụng dịch vụ nâng cao Chat, bạn phải thêm phạm vi uỷ quyền mà tập lệnh sử dụng vào tệp kê khai của dự án Apps Script theo cách thủ công. Xem phần Đặt phạm vi rõ ràng.
Để giải quyết lỗi này, hãy thêm các phạm vi uỷ quyền thích hợp vào tệp appsscript.json
của dự án Apps Script như một phần của mảng oauthScopes
. Ví dụ: để gọi phương thức spaces.messages.create
, hãy thêm nội dung sau:
"oauthScopes": [
"https://www.googleapis.com/auth/chat.messages.create"
]
Giới hạn và điều cần cân nhắc
Dịch vụ Chat nâng cao không hỗ trợ:
- Phương thức Chat API
media.download
. - Các phương thức Chat API có trong Bản dùng thử cho nhà phát triển
Để tải tệp đính kèm của thư xuống hoặc gọi phương thức xem trước dành cho nhà phát triển, hãy sử dụng UrlFetchApp
.