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