Trang này giải thích cách gia hạn Gói thuê bao của Google Workspace bằng phương thức subscriptions.update(). Sử dụng phương thức này để cập nhật thời gian hết hạn của một gói thuê bao, bao gồm cả việc gia hạn gói thuê bao trong thời gian hết hạn tối đa có thể hoặc để cập nhật danh sách các loại sự kiện cần nhận về tài nguyên mục tiêu.
Apps Script
- Gói thuê bao của Google Workspace. Để tạo một gói thuê bao, hãy xem phần Tạo gói thuê bao.
- Một dự án Apps Script:
- Sử dụng dự án trên đám mây của Google thay vì dự án mặc định do Apps Script tự động tạo.
- Đối với tất cả các phạm vi mà bạn đã thêm để định cấu hình màn hình xin phép bằng OAuth, bạn cũng phải thêm các phạm vi đó vào tệp
appsscript.jsontrong dự án Apps Script. Ví dụ: nếu bạn chỉ định phạm vichat.messages, hãy thêm nội dung sau: - Bật dịch vụ nâng cao
Google Workspace Events.
"oauthScopes": [ "https://www.googleapis.com/auth/chat.messages" ]
Yêu cầu xác thực và phạm vi uỷ quyền thích hợp cho từng loại sự kiện trong gói thuê bao:
- Đối với hoạt động xác thực người dùng, cần có một hoặc nhiều phạm vi hỗ trợ ít nhất một trong các loại sự kiện cho gói thuê bao. Để xác định phạm vi, hãy xem bài viết Phạm vi theo loại sự kiện.
- Để đăng ký một sự kiện Chat dưới dạng ứng dụng Chat, bạn cần phải xác thực ứng dụng và quản trị viên phê duyệt một lần.
Python
- Python 3.6 trở lên
- Công cụ quản lý gói pip
- Thư viện ứng dụng mới nhất của Google cho Python. Để cài đặt hoặc cập nhật các công cụ này, hãy chạy lệnh sau trong giao diện dòng lệnh:
pip3 install --upgrade google-api-python-client google-auth-oauthlib
- Gói thuê bao của Google Workspace. Để tạo một gói thuê bao, hãy xem phần Tạo gói thuê bao.
Yêu cầu xác thực và phạm vi uỷ quyền thích hợp cho từng loại sự kiện trong gói thuê bao:
- Đối với hoạt động xác thực người dùng, cần có một hoặc nhiều phạm vi hỗ trợ ít nhất một trong các loại sự kiện cho gói thuê bao. Để xác định phạm vi, hãy xem bài viết Phạm vi theo loại sự kiện.
- Để đăng ký một sự kiện Chat dưới dạng ứng dụng Chat, bạn cần phải xác thực ứng dụng và quản trị viên phê duyệt một lần.
Gia hạn gói thuê bao của Google Workspace
Trong phần này, hãy sử dụng phương thức subscriptions.update() của Google Workspace Events API để gia hạn gói thuê bao đến thời gian hết hạn tối đa. Để chỉ định thời gian hết hạn tối đa, hãy cập nhật trường ttl của tài nguyên Subscription thành 0.
Thời gian hết hạn tối đa phụ thuộc vào dữ liệu tài nguyên có trong tải trọng sự kiện. Để tìm hiểu thêm về thời gian hết hạn, hãy xem bài viết Dữ liệu sự kiện cho các sự kiện trên Google Workspace.
Cách gia hạn gói thuê bao của Google Workspace:
Apps Script
Trong dự án Apps Script, hãy tạo một tệp kịch bản mới có tên là
updateSubscriptionrồi thêm mã sau:function updateSubscription() { // The name of the subscription to update. const name = 'subscriptions/SUBSCRIPTION_ID'; // Call the Workspace Events API using the advanced service. const response = WorkspaceEvents.Subscriptions.patch({ ttl: '0s', }, name); console.log(response); }Thay thế nội dung sau:
Để cập nhật gói thuê bao Google Workspace, hãy chạy hàm
updateSubscriptiontrong dự án Apps Script của bạn.
Python
Trong thư mục làm việc, hãy tạo một tệp có tên là
update_subscription.pyrồi thêm đoạn mã sau:"""Update subscription.""" from google_auth_oauthlib.flow import InstalledAppFlow from googleapiclient.discovery import build # Specify required scopes. SCOPES = [SCOPES] # Authenticate with Google Workspace and get user authentication. flow = InstalledAppFlow.from_client_secrets_file('credentials.json', SCOPES) CREDENTIALS = flow.run_local_server() # Call the Workspace Events API using the service endpoint. service = build( 'workspaceevents', 'v1', credentials=CREDENTIALS, ) BODY = { 'ttl': {'seconds': 0}, } NAME = 'subscriptions/SUBSCRIPTION_ID' response = ( service.subscriptions() .patch(name=NAME, updateMask='ttl', body=BODY) .execute() ) print(response)Thay thế nội dung sau:
SCOPES: Một hoặc nhiều phạm vi OAuth hỗ trợ từng loại sự kiện cho gói thuê bao. Được định dạng dưới dạng một mảng chuỗi. Để liệt kê nhiều phạm vi, hãy phân tách bằng dấu phẩy. Ví dụ:'https://www.googleapis.com/auth/chat.spaces.readonly', 'https://www.googleapis.com/auth/chat.memberships.readonly'.SUBSCRIPTION_ID: Mã nhận dạng của gói thuê bao. Để lấy mã nhận dạng, bạn có thể sử dụng bất kỳ phương thức nào sau đây:
Trong thư mục làm việc, hãy đảm bảo bạn đã lưu trữ thông tin đăng nhập Ứng dụng OAuth và đặt tên cho tệp là
credentials.json. Mã mẫu này sử dụng tệp JSON này để xác thực với Google Workspace và lấy thông tin đăng nhập của người dùng. Để biết hướng dẫn, hãy xem phần Tạo thông tin đăng nhập mã ứng dụng khách OAuth.Để cập nhật gói thuê bao của Google Workspace, hãy chạy lệnh sau trong thiết bị đầu cuối:
python3 update_subscription.py
Subscription.
Để biết thông tin chi tiết về tài nguyên Subscription đã cập nhật, hãy sử dụng phương thức operations.get() và chỉ định tài nguyên Operation được trả về từ yêu cầu subscriptions.update() của bạn. Nếu không, nếu bạn chỉ định một tài nguyên Operation từ phiên bản trước của gói thuê bao, thì phản hồi sẽ trống.
Cập nhật hoặc gia hạn gói thuê bao dưới dạng ứng dụng Google Chat
Bạn có thể cập nhật hoặc gia hạn gói thuê bao cho các sự kiện trên Chat dưới dạng một ứng dụng Chat thay vì dưới dạng người dùng. Quy trình này tương tự, ngoại trừ:
Thay vì xác thực người dùng, hãy xác thực dưới dạng một ứng dụng Chat bằng quy trình phê duyệt một lần của quản trị viên.
Chỉ định các phạm vi uỷ quyền cho phép ứng dụng Chat đăng ký nhận các sự kiện trên Chat. Các phạm vi uỷ quyền này luôn bắt đầu bằng
chat.appvà bao gồm những phạm vi sau:https://www.googleapis.com/auth/chat.app.memberships: Đăng ký nhận thông báo về sự kiện của thành viên trong phòng Chat.https://www.googleapis.com/auth/chat.app.memberships.readonly: Đăng ký nhận thông báo về sự kiện của thành viên trong phòng Chat.https://www.googleapis.com/auth/chat.app.messages.readonly: Đăng ký nhận sự kiện tin nhắn trong phòng Chat.https://www.googleapis.com/auth/chat.app.spaces: Đăng ký nhận thông báo về các sự kiện trong phòng Chat.https://www.googleapis.com/auth/chat.app.spaces.readonly: Đăng ký nhận thông báo về các sự kiện trong phòng Chat.
Viết một tập lệnh gọi Google Workspace Events API
Mẫu mã sau đây cập nhật gói thuê bao Google Workspace của một ứng dụng Chat:
Python
"""Update subscription."""
from google.oauth2 import service_account
from apiclient.discovery import build
# Specify required scopes.
SCOPES = [SCOPES]
# Specify service account details.
CREDENTIALS = (
service_account.Credentials.from_service_account_file('credentials.json')
.with_scopes(SCOPES)
)
# Call the Workspace Events API using the service endpoint.
service = build(
'workspaceevents',
'v1beta',
credentials=CREDENTIALS,
)
BODY = {
'ttl': {'seconds': 0},
}
NAME = 'subscriptions/SUBSCRIPTION_ID'
response = (
service.subscriptions()
.patch(name=NAME, updateMask='ttl', body=BODY)
.execute()
)
print(response)
Thay thế nội dung sau:
SCOPES: Chỉ định các phạm vi uỷ quyền cho phép ứng dụng Chat đăng ký nhận các sự kiện trên Chat. Các phạm vi uỷ quyền này luôn bắt đầu bằngchat.appvà bao gồm những phạm vi sau:https://www.googleapis.com/auth/chat.app.memberships: Đăng ký nhận thông báo về sự kiện của thành viên trong phòng Chat.https://www.googleapis.com/auth/chat.app.memberships.readonly: Đăng ký nhận thông báo về sự kiện của thành viên trong phòng Chat.https://www.googleapis.com/auth/chat.app.messages.readonly: Đăng ký nhận sự kiện về tin nhắn và lượt thể hiện cảm xúc trong phòng Chat.https://www.googleapis.com/auth/chat.app.spaces: Đăng ký nhận thông báo về các sự kiện trong phòng Chat.https://www.googleapis.com/auth/chat.app.spaces.readonly: Đăng ký nhận thông báo về các sự kiện trong phòng Chat.
SUBSCRIPTION_ID: Mã nhận dạng của gói thuê bao. Để lấy mã nhận dạng, bạn có thể dùng một trong những cách sau: