要求
HTTP 要求
PUT https://www.googleapis.com/calendar/v3/calendars/calendarId/acl/ruleId
參數
參數名稱 | 值 | 說明 |
---|---|---|
路徑參數 | ||
calendarId |
string |
日曆 ID。如要擷取日曆 ID,請呼叫 calendarList.list 方法。如果您想存取目前登入使用者的主日曆,請使用「primary 」關鍵字。
|
ruleId |
string |
ACL 規則 ID。 |
選用查詢參數 | ||
sendNotifications |
boolean |
是否要傳送日曆共用變更通知。請注意,系統不會發出存取權移除通知。選用設定。預設值為 True。 |
授權
這項要求需要至少具備下列其中一個範圍的授權:
範圍 |
---|
https://www.googleapis.com/auth/calendar |
https://www.googleapis.com/auth/calendar.acls |
詳情請參閱「驗證和授權」頁面。
要求主體
在要求主體中,請提供具有下列屬性的 Acl 資源:
屬性名稱 | 值 | 說明 | 附註 |
---|---|---|---|
必要屬性 | |||
scope |
object |
這項 ACL 規則授予的日曆存取權程度。 | |
scope.type |
string |
範圍的類型。可能的值包括:
default 」或公開範圍的權限,會套用至任何使用者 (無論是否經過驗證)。 |
|
選用屬性 | |||
role |
string |
指派給範圍的角色。可能的值包括:
|
可寫入 |
scope.value |
string |
使用者或群組的電子郵件地址,或網域名稱 (視範圍類型而定)。對於類型「default 」,則省略。 |
可寫入 |
回應
如果成功的話,這個方法會在回應內文中傳回 Acl 資源。
範例
注意:這個方法適用的程式語言眾多,我們只在此提供部分程式碼範例,完整的支援語言清單請參閱用戶端程式庫頁面。
Java
使用 Java 用戶端程式庫。
import com.google.api.services.calendar.Calendar; import com.google.api.services.calendar.model.AclRule; // ... // Initialize Calendar service with valid OAuth credentials Calendar service = new Calendar.Builder(httpTransport, jsonFactory, credentials) .setApplicationName("applicationName").build(); // Retrieve the access rule from the API AclRule rule = service.acl().get('primary', "ruleId").execute(); // Make a change rule.setRole("newRole"); // Update the access rule AclRule updatedRule = service.acl().update('primary', rule.getId(), rule).execute(); System.out.println(updatedRule.getEtag());
Python
使用 Python 用戶端程式庫。
rule = service.acl().get(calendarId='primary', ruleId='ruleId').execute() rule['role'] = 'newRole' updated_rule = service.acl().update(calendarId='primary', ruleId=rule['id'], body=rule).execute() print updated_rule['etag']
PHP
使用 PHP 用戶端程式庫。
$rule = $service->acl->get('primary', 'ruleId'); $rule->setRole('newRole'); $updatedRule = $service->acl->update('primary', $rule->getId(), $rule); echo $updatedRule->getEtag();
小茹
使用 Ruby 用戶端程式庫。
rule = client.get_acl('primary', 'ruleId') rule.role = 'newRole' result = client.update_acl('primary', rule.id, rule) print result.etag
試試看!
您可以使用下方的 API Explorer,針對即時資料呼叫這個方法,然後查看回應。