Acl: insert

アクセス制御ルールを作成します。今すぐ試すまたは例を見る

リクエスト

HTTP リクエスト

POST https://www.googleapis.com/calendar/v3/calendars/calendarId/acl

パラメータ

パラメータ名 説明
パスパラメータ
calendarId string カレンダー ID。カレンダー ID を取得するには、calendarList.list メソッドを呼び出します。現在ログインしているユーザーのメイン カレンダーにアクセスするには、「primary」キーワードを使用します。
省略可能なクエリ パラメータ
sendNotifications boolean カレンダーの共有の変更に関する通知を送信するかどうか。省略可。デフォルトは True です。

承認

このリクエストは、少なくとも次のうち 1 つのスコープによる承認が必要です。

範囲
https://www.googleapis.com/auth/calendar
https://www.googleapis.com/auth/calendar.acls

詳しくは、認証と認可のページをご覧ください。

リクエストの本文

リクエストの本文には、以下のプロパティを使用して Acl リソースを指定します。

プロパティ名 説明 メモ
必須プロパティ
role string スコープに割り当てられたロール。指定できる値は次のとおりです。
  • none」- アクセス権を付与しません。
  • freeBusyReader」- 空き/不在情報への読み取りアクセス権を付与します。
  • reader」 - カレンダーへの読み取りアクセス権を付与します。限定公開のイベントは、閲覧者権限を持つユーザーには表示されますが、イベントの詳細は非表示になります。
  • writer」- カレンダーに対する読み取り / 書き込みアクセス権を付与します。非公開イベントは、作成者権限を持つユーザーに表示され、イベントの詳細も表示されます。カレンダーの ACL への読み取りアクセス権を付与します。
  • owner」 - カレンダーのオーナー権限を付与します。このロールには、書き込みロールのすべての権限に加えて、ACL を操作する権限が付与されています。
書き込み可能
scope object この ACL ルールによってカレンダーへのアクセスが許可される範囲。
scope.type string スコープのタイプ。指定できる値は次のとおりです。
  • default」- 公開スコープ。これがデフォルト値です。
  • user」- スコープを 1 人のユーザーに制限します。
  • group」 - スコープをグループに制限します。
  • domain」 - スコープをドメインに制限します。
注: 「default」スコープ(公開スコープ)に付与された権限は、認証されているかどうかにかかわらず、すべてのユーザーに適用されます。
省略可能なプロパティ
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();

// Create access rule with associated scope
AclRule rule = new AclRule();
Scope scope = new Scope();
scope.setType("scopeType").setValue("scopeValue");
rule.setScope(scope).setRole("role");

// Insert new access rule
AclRule createdRule = service.acl().insert('primary', rule).execute();
System.out.println(createdRule.getId());

Python

Python クライアント ライブラリを使用します。

rule = {
    'scope': {
        'type': 'scopeType',
        'value': 'scopeEmail',
    },
    'role': 'role'
}

created_rule = service.acl().insert(calendarId='primary', body=rule).execute()

print created_rule['id']

PHP

PHP クライアント ライブラリを使用します。

$rule = new Google_Service_Calendar_AclRule();
$scope = new Google_Service_Calendar_AclRuleScope();

$scope->setType("scopeType");
$scope->setValue("scopeValue");
$rule->setScope($scope);
$rule->setRole("role");

$createdRule = $service->acl->insert('primary', $rule);
echo $createdRule->getId();

Ruby

Ruby クライアント ライブラリを使用します。

rule = Google::Apis::CalendarV3::AclRule.new(
  scope: {
    type: 'scopeType',
    value: 'scopeEmail',
  },
  role: 'role'
)
result = client.insert_acl('primary', rule)
print result.id

試してみよう:

以下の API Explorer を使用して、ライブデータに対してこのメソッドを呼び出し、レスポンスを確認します。