高度なカレンダー サービスでは、Apps Script の公開 Google Calendar API を使用できます。Apps Script の組み込みカレンダー サービスと同様に、この API を使用すると、ユーザーの Google カレンダー(ユーザーが登録している追加のカレンダーを含む)にアクセスして変更できるようになります。ほとんどの場合、組み込みサービスが使いやすくなりますが、この高度なサービスでは、個々のイベントの背景色を設定するなど、いくつかの追加機能を利用できます。
Reference
このサービスの詳細については、一般公開の Google Calendar API のリファレンス ドキュメントをご覧ください。Apps Script のすべての高度なサービスと同様に、高度なカレンダー サービスでも公開 API と同じオブジェクト、メソッド、パラメータを使用します。詳細については、メソッド シグネチャの決定方法をご覧ください。
問題を報告し、その他のサポートを確認する方法については、カレンダー サポートガイドをご覧ください。
HTTP リクエスト ヘッダー
高度なカレンダー サービスは、HTTP リクエスト ヘッダー If-Match
と If-None-Match
を受け入れることができます。詳しくは、リファレンス ドキュメントをご覧ください。
サンプルコード
以下のサンプルコードでは、バージョン 3 の API を使用しています。
イベントの作成
次の例は、ユーザーのデフォルトのカレンダーで予定を作成する方法を示しています。
カレンダーの一覧表示
次の例は、ユーザーのカレンダー リストに表示されているカレンダーの詳細を取得する方法を示しています。
イベントの一覧表示
次の例は、ユーザーのデフォルト カレンダーの次の 10 件の予定を一覧表示する方法を示しています。
イベントの条件付き変更
次の例は、If-Match
ヘッダーを使用して条件付きでカレンダーの予定を更新する方法を示しています。このスクリプトは新しいイベントを作成し、30 秒待機してから、イベントの作成後にイベントの詳細が変更されない場合にのみイベントを更新します。
条件付きでイベントを取得する
次の例は、If-None-Match
ヘッダーを使用して条件付きでカレンダーの予定を取得する方法を示しています。このスクリプトは新しいイベントを作成し、その後 30 秒間変更をポーリングします。イベントが変更されるたびに、新しいバージョンが取得されます。
イベントの同期
次の例は、同期トークンを使用してイベントを取得する方法を示しています。高度なトークン リクエストを同期トークンに含めると、生成されるトークンに、そのトークンの生成後に変更されたアイテムのみが含まれるため、処理の効率が向上します。同期プロセスの詳細については、リソースを効率的に同期するをご覧ください。
次の例では、上記の例で定義されている同じ getRelativeDate(daysOffset, hour)
メソッドを使用しています。