Outlook のプッシュ通知の REST API リファレンス (バージョン 2.0)
適用対象: Exchange Online | Office 365 | Hotmail.com | Live.com | MSN.com | Outlook.com | Passport.com
Outlook プッシュ通知 REST API は Webhook を使用してクライアント側の Web サービスに通知を送信し、ユーザーのメールボックス データに加えられた変更についてアプリに通知します。対象のデータは、Azure Active Directory によってセキュリティで保護されている Office 365 内、または Microsoft アカウント (具体的には次のドメイン) 内のユーザーのメール、予定表、連絡先、またはタスク データ内にあります。Hotmail.com、Live.com、MSN.com、Outlook.com、および Passport.com。
注意
リファレンスをわかりやすくするため、この記事の残りの部分では Outlook.com を、これら Microsoft のアカウント ドメインを含無ものとして使用しています。
API v2.0 が不要な場合 左の目次で、** Office 365 REST API リファレンス ** セクションに移動し、使用したいバージョンを選択します。
概要
Office 365 プッシュ通知サービスと API は、コールバック アドレスを Web サービスに提供するクライアントを処理し、Webhook を使用してクライアント アプリに通知を配信します。Webhook は、通常、サード パーティの信頼されたバックエンド Web サービスで構成されている HTTP コールバックです。Web サービスは、1 つのサイトでトリガー イベントを発生させて別のサイトで動作を呼び出すように Webhook を構成できます。
アプリが特定のリソース (ユーザーの受信トレイ内のメッセージなど) の通知をサブスクライブする場合は、サブスクリプション要求に Webhook コールバック URL を指定します。トリガー イベント (受信トレイの新しいメッセージなど) が発生すると、Office 365 通知サービスは、コールバック URL に Webhook を使用して通知をプッシュします。次に、アプリが、新しいメッセージを取得する、未読のカウントを更新するなど、ビジネス ロジックに従って、アクションを実施します。
アプリは、期限が切れる前にサブスクリプションを更新する必要があります。また、サブスクリプションを中止して、通知の受信をいつでも停止することができます。
ストリーミングとプッシュ通知の比較
メール、予定表、CRM アプリは通常、通知を使用して、ローカル キャッシュ、対応するクライアントのビュー、またはバックエンド システムで変更を更新します。Outlook は、ストリーミング通知とプッシュ通知の両方をサポートしています。現時点で、プッシュ通知は一般にモバイル アプリで使用されています。クライアントは変更をポーリングする必要がなく、更新内容はクライアントに対してほぼ瞬時に利用可能になるからです。
プッシュ通知とストリーミング通知と比較すると、プッシュ通知の場合、クライアントは通知を取得するために独自の Web サービスを提供する必要がありますが、ストリーミング通知の場合は、クライアントと Office 365 のストリーミング通知サービスとの間の直接接続しか必要としません。
プッシュ通知 REST API の使用
認証
サブスクリプションの登録、クエリの実行、更新、削除を行うには、通知対象のリソースの種類に適したスコープを指定します。
最低限必要なスコープ
対象リソースに対応する次の読み取りスコープのうちのいずれかです。
- https://outlook.office.com/mail.read
- https://outlook.office.com/calendars.read
- https://outlook.office.com/contacts.read
- https://outlook.office.com/tasks.read
- wl.imap
- wl.calendars
- wl.contacts_calendars
- wl.basic
他の Outlook REST API と同様に、Outlook プッシュ通知 API へのすべての要求に、有効なアクセス トークンを含める必要があります。 アクセス トークンを取得するには、アプリを登録して識別させ、適切な承認を取得する必要があります。
効率化された登録と承認のオプションに関する詳細情報を参照してください。 プッシュ通知 API で特定の操作を続行する際には、この点にご留意ください。
API のバージョン
この API は、プレビューから一般提供 (GA) の状態にレベル上げされています。Outlook REST API の v2.0 とベータのバージョンでサポートされます。
ターゲット ユーザー
プッシュ通知 API 要求は、常に現在のユーザーのために実行されます。
Outlook REST API のすべてのサブセットに共通な情報について詳しくは、「Outlook REST API の使用」を参照してください。
プッシュ通知の操作
自分のメール、予定表、連絡先、およびタスクの変更のサブスクライブ
サブスクリプション プロセス
サブスクリプション プロセスは、次のようになります。
クライアント アプリが、特定のリソースのサブスクリプション要求 (POST) を行います。それには通知 URL などのプロパティが含まれます。
Outlook の通知サービスは、リスナー サービスによって通知 URL を検証しようとします。これには、検証要求の検証トークンが含まれます。
リスナー サービスが正常に URL の検証を行った場合、次のように成功の応答を 5 秒以内に返します。
- 応答ヘッダーのコンテンツ タイプを text\plain に設定します。
- 応答の本文に同じ検証トークンを含めます。
- HTTP 200 の応答コードを返します。リスナーは、その後の検証トークンを破棄できます。
URL の検証結果に応じて、Outlook の通知サービスはクライアント アプリに応答を送信します。
- URL の検証が成功した場合、サービスは一意なサブスクリプション ID を持つサブスクリプションを作成し、クライアントへの応答を送信します。
- URL の検証が正常に終了しない場合、サービスはエラー コードとその他の詳細を含むエラー応答を送信します。
クライアント アプリは、正常な応答を受信すると、将来の通知をこのサブスクリプションと関連付けるため、サブスクリプション ID を格納します。
サブスクリプション要求
リスナー サービスをサブスクライブして、Office 365 または Outlook.com でメール、予定表イベント、連絡先、またはタスクが変更されたときに通知を受信します。これは、クライアントがリソース (エンティティまたはエンティティのコレクション) の通知の取得を開始する最初のステップです。
POST https://outlook.office.com/api/v2.0/me/subscriptions
要求本文で、プッシュ サブスクリプション要求に対して次のプロパティを指定します。ClientState 以外のすべてのプロパティが必須です。詳細については、 Notification エンティティをご覧ください。
- odata.type -
"@odata.type":"#Microsoft.OutlookServices.PushSubscription"
を含めます。 PushSubscription エンティティは NotificationURL を定義します。 - ChangeType - そのリソースで監視するイベントの種類を指定します。サポートされる種類については、ChangeType をご覧ください。
- ClientState - 同じ ClientState の値のヘッダーで各通知が送信されなければならないことを示す、オプションのプロパティ。これにより、リスナーは各通知の正当性を確認できます。
- NotificationURL - 通知の送信先を指定します。この URL は、通常クライアントで実装される Web サービスを表します。
- Resource - 監視対象のリソースを指定します。その通知を受け取ることになります。 オプションのクエリ パラメーター
$filter
を使用して通知の条件を絞り込むか、$select
を使用してリッチ通知に特定のプロパティを含めることができます。
サポートされているリソースは次のとおりです。
メッセージ、イベント、連絡先、タスクの通常のフォルダーまたは検索フォルダー。例:
https://outlook.office.com/api/v2.0/me/mailfolders('inbox')/messages
https://outlook.office.com/api/v2.0/me/taskfolders('{folder_id}')/tasks
または、メッセージ、イベント、連絡先、またはタスクのトップレベルのエンティティのコレクション。
https://outlook.office.com/api/v2.0/me/messages
https://outlook.office.com/api/v2.0/me/events
https://outlook.office.com/api/v2.0/me/contacts
https://outlook.office.com/api/v2.0/me/tasks
要求のサンプル
次の例は、新しいイベントをサブスクライブする方法を示しています。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
"@odata.type":"#Microsoft.OutlookServices.PushSubscription",
"Resource": "https://outlook.office.com/api/v2.0/me/events",
"NotificationURL": "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
"ChangeType": "Created",
"ClientState": "c75831bd-fad3-4191-9a66-280a48528679"
}
通知条件を絞り込む
$filter
クエリ パラメーターを使用すれば、通知の条件をさらに詳細に設定することができます。
次の例では、下書きフォルダーで作成中で、1 つまたは複数の添付ファイルを含み、重要度が High
のメッセージに関して通知を要求します。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
@odata.type:"#Microsoft.OutlookServices.PushSubscription",
Resource: "https://outlook.office.com/api/v2.0/me/mailfolders('Drafts')/messages?$filter=HasAttachments%20eq%20true%20AND%20Importance%20eq%20%27High%27",
NotificationURL: "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
ChangeType: "Created",
ClientState: "Has attachments and high importance"
}
次の例では、作成中の終日イベントに関して通知を要求します。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
@odata.type:"#Microsoft.OutlookServices.PushSubscription",
Resource: "https://outlook.office.com/api/v2.0/me/events?$filter=IsAllDay%20eq%20true",
NotificationURL: "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
ChangeType: "Created",
ClientState: "Notifications for events that IsAllDay."
}
次の例では、Contoso という会社の、作成中の Contact に関する通知を要求します。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
@odata.type:"#Microsoft.OutlookServices.PushSubscription",
Resource: "https://outlook.office.com/api/v2.0/me/contacts?$filter=CompanyName%20eq%20%27Contoso%27",
NotificationURL: "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
ChangeType: "Created",
ClientState: "Contacts in Contoso."
}
の一般的な使用方法として、指定されたリソースの特定のプロパティが変化したら通知を受けるというものがあります。$filter
たとえば、$filter
を使用して、フォルダー内の未読メッセージ (IsRead プロパティが false) を受信し、すべての変更の種類を含めることができます。
- フォルダー内の追加されたメッセージ、または未読のマークが付けられているメッセージにより、
Created
通知がトリガーされます。 - フォルダー内のメッセージを閲覧すること、またはメッセージに開封済みのマークを付けることにより、
Deleted
通知がトリガーされます。 - フォルダー内のメッセージで IsRead 以外のプロパティを変更すると、
Updated
通知がトリガーされます。
そのようなサブスクリプションを次のように作成することができます。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
@odata.type:"#Microsoft.OutlookServices.PushSubscription",
Resource: "https://outlook.office.com/api/v2.0/me/mailfolders('folder_id')/messages$filter=IsRead%20eq%20false",
NotificationURL: "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
ChangeType: "Created,Deleted,Updated",
ClientState: "Message unread"
}
サブスクリプションを作成するときに $filter
を使用しない場合 (以下に例を挙げます)、次のようになります。
- フォルダーにメッセージを追加すると、結果として
Created
通知が行われます。 - フォルダー内のメッセージの閲覧、メッセージに開封済みのマークを付けること、またはフォルダー内のメッセージのその他のプロパティを変更することにより、結果として
Updated
通知が行われます。 - メッセージを削除すると、結果として
Delete
通知が行われます。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
@odata.type:"#Microsoft.OutlookServices.PushSubscription",
Resource: "https://outlook.office.com/api/v2.0/me/mailfolders('folder_id')/messages,
NotificationURL: "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
ChangeType: "Created,Deleted,Updated",
ClientState: "Message unread"
}
検証要求
検証要求は、サブスクリプション要求でクライアント アプリが指定する NotificationURL を検証しようとします。
POST https://{notificationUrl}?validationToken={token}
Outlook のサービスでは、サブスクリプション要求の NotificationURL を{notificationUrl} で指定し、文字列 {token} を検証トークンとして定義します。クライアント アプリがサブスクリプション要求に ClientState ヘッダーを含める場合、Outlook サービスもそのヘッダーを含めます。
サブスクリプション応答
サブスクリプション応答には、要求のプロパティ、および次の追加のプロパティが含まれています。
- Id – 今後の通知と一致するようにクライアント アプリが保存する必要がある一意なサブスクリプション ID。
- ChangeType - 要求で指定された値とは別に、追加の通知タイプである Missed が応答に含まれます。
- SubscriptionExpirationDateTime - サブスクリプションの有効期限が切れる日付と時刻。サブスクリプション要求に有効期限の時刻を指定しない場合、または要求が最大時間よりも長い有効期限を指定している場合、このプロパティは要求が送信された時刻からの最大時間に設定されます。特定のプロパティのリッチ通知を要求するサブスクリプションについて、最大許容値は 1 日です。その他のサブスクリプションでは、最大値は 7 日間です。
- 他の OData 関連のプロパティ。
応答データのサンプル
この応答では、リスナー サービスが新しいイベントと失敗した変更の通知の受信を想定していることを示します。変更に失敗した場合、クライアントはその変更をキャプチャするためにサービスと同期する必要があります。
{
"@odata.context": "https://outlook.office.com/api/v2.0/$metadata#Me/Subscriptions/$entity",
"@odata.type": "#Microsoft.OutlookServices.PushSubscription",
"@odata.id": "https://outlook.office.com/api/v2.0/Users('ddfcd489-628b-7d04-b48b-20075df800e5@1717622f-1d94-c0d4-9d74-f907ad6677b4')/Subscriptions('Mjk3QNERDQQ==')",
"Id": "Mjk3QNERDQQ==",
"Resource": "https://outlook.office.com/api/v2.0/me/events",
"ChangeType": "Created, Missed",
"ClientState": "c75831bd-fad3-4191-9a66-280a48528679",
"NotificationURL": "https://mywebhook.azurewebsites.net/api/send/myNotifyClient",
"SubscriptionExpirationDateTime": "2015-04-23T22:46:13.8805047Z"
}
サブスクリプションのクエリを実行する
サインインしているユーザーの既存のサブスクリプションのいずれかに関する詳細情報を検索するには、そのサブスクリプション ID を指定します。たとえば、最後の例で作成したサブスクリプションのクエリを実行するには、次のようにします。
GET https://outlook.office.com/api/v2.0/Users('ddfcd489-628b-7d04-b48b-20075df800e5@1717622f-1d94-c0d4-9d74-f907ad6677b4')/Subscriptions('Mjk3QNERDQQ==')
成功すると、クライアント アプリケーションが潜在的なセキュリティ リスクを回避するために指定した ClientState を除外するという点を除き、応答はサンプルの最後の応答データと同じです。
通知
各通知には、その種類に関係なく、次のプロパティが含まれています。
- ClientState ヘッダー - クライアントがサブスクリプション要求で ClientState プロパティを指定した場合にのみ存在します。通知の正当性を確認するために、リスナーによって使用されます。
- SubscriptionId - この通知が所属するサブスクリプションをクライアント アプリに識別させます。
- SubscriptionExpirationDateTime - サブスクリプションの有効期限が切れる日付と時刻。
- SequenceNumber - 通知が欠落していないかどうかをクライアント アプリが識別できるようにする、通知の連続した番号。
- ChangeType - クライアント アプリケーションに通知しようとしているイベントの種類 (たとえば、メールを受信したときの Created イベント、メッセージを読むときの Update イベント)。
- Resource – 監視されている特定のリソース アイテムの URL (変更されたメッセージまたはイベントへの URL など)。
- ResourceData - リソースの変更に関連する通知 (メッセージを受信する、読む、削除するなど) が、変更されたアイテムのリソース ID を含むこの追加のプロパティを持っています。クライアントはこのリソース ID を使用して、ビジネス ロジック (このアイテムをフェッチする、フォルダーを同期するなど) に従ってこのアイテムを処理できます
注意
Notification エンティティでは、Id プロパティは使用されません。
変更通知のペイロード
次の例では、ユーザーが新しいイベントを受け取ると、通知サービスは ChangeType を "Created" に設定した通知を送信します。通知のヘッダーには、初期サブスクリプション要求で指定されている ClientState が含まれます。受信イベントの通知には、次のようなペイロードがあります。
{
"value": [
{
"@odata.type": "#Microsoft.OutlookServices.Notification",
"Id": null,
"SubscriptionId": "Mjk3QNERDQQ==",
"SubscriptionExpirationDateTime": "2015-04-23T22:46:13.8805047Z",
"SequenceNumber": 1,
"ChangeType": "Created",
"Resource" : "https://outlook.office.com/api/v2.0/Users('ddfcd489-628b-7d04-b48b-20075df800e5@1717622f-1d94-c0d4-9d74-f907ad6677b4')/Events('AAMkADNkNmAA=')",
"ResourceData": {
"@odata.type": "#Microsoft.OutlookServices.Event",
"@odata.id": "https://outlook.office.com/api/v2.0/Users('ddfcd489-628b-7d04-b48b-20075df800e5@1717622f-1d94-c0d4-9d74-f907ad6677b4')/Events('AAMkADNkNmAA=')",
"Id": "AAMkADNkNmAA="
}
}
]
}
リッチ通知へのサブスクライブによってインスタンス プロパティを取得する
変更通知ペイロードの最後の例に示したとおり、リソース コレクションに設定したプッシュ通知のサブスクリプションでは、変更されたリソース インスタンスの ID だけを返します。そのインスタンスのプロパティを別に取得する必要があります。
サブスクリプション要求で $select
パラメーターを使用して、必要なプロパティを指定する場合、別の GET API 呼び出しを保存できます。次に、イベントが作成された場合に、通知に subject プロパティを含めるよう要求する例を示します。
POST https://outlook.office.com/api/v2.0/me/subscriptions HTTP/1.1
Content-Type: application/json
{
"@odata.type":"#Microsoft.OutlookServices.PushSubscription",
"Resource": "https://outlook.office.com/api/v2.0/me/events?$select=Subject",
"NotificationURL": "https://mywebhook.azurewebsites.net/api/send/myRichNotifyClient",
"ChangeType": "Created"
}
リッチ通知ペイロードのサンプル
リッチ通知ペイロードには、サブスクリプション要求で指定したプロパティの値が含まれます。前の例に従い、リッチ通知には次のように Subject プロパティが含まれています。
{
"@odata.context": "https://outlook.office.com/api/v2.0/$metadata#Notifications",
{
"@odata.type": "#Microsoft.OutlookServices.Notification",
"Id": null,
"SubscriptionId": "QjQzNzAwBQQ==",
"SubscriptionExpirationDateTime": "2017-01-18T00:57:28.6134733Z",
"SequenceNumber": 1,
"ChangeType": "Created",
"Resource": "https://outlook.office.com/api/v2.0/Users('6ed6de00-b4c1-4f9b-8ce0-30908c54da0a@ea54488f-a8f6-4c8d-acad-c3a1da54f79f')/Events('AAMkAGAAAAACisAAA=')",
"ResourceData": {
"@odata.type": "#Microsoft.OutlookServices.Event",
"@odata.id": "https://outlook.office.com/api/v2.0/Users('6ed6de00-b4c1-4f9b-8ce0-30908c54da0a@ea54488f-a8f6-4c8d-acad-c3a1da54f79f')/Events('AAMkAGAAAAACisAAA=')",
"@odata.etag": "W/\"IpGjeMHoYUS/RhJxluiSeAAAAAAyoQ==\"",
"Id": "AAMkAGAAAAACisAAA=",
"Subject": "Quarterly meeting CY17Q1"
}
}
]
}
サブスクリプションを更新する
更新要求の時間から最大時間までサブスクリプションを更新します。
PATCH https://outlook.office.com/api/v2.0/me/subscriptions/{subscriptionId}
応答に特定のインスタンス プロパティを必要としないサブスクリプション要求では既定のサブスクリプション時間は 7 日であり、リッチ通知のサブスクリプションでは 1 日です。
ペイロードなしで更新要求を送信することができ、サブスクリプションは対応する最大期間だけ延長されます。
要求のサンプル
PATCH https://outlook.office.com/api/v2.0/me/subscriptions/Mjk3QNERDQQ==
{
@odata.type:"#Microsoft.OutlookServices.PushSubscription",
"SubscriptionExpirationDateTime": "2015-05-28T17:17:45.9028722Z"
}
応答
成功した応答は、HTTP 200 応答コードで示されます。
サブスクリプションを削除する
サブスクリプション ID を指定して、サブスクリプションを削除します。
DELETE https://outlook.office.com/api/v2.0/me/subscriptions('{subscriptionId}')
要求のサンプル
Delete https://outlook.office.com/api/v2.0/me/subscriptions('Mjk3QNERDQQ==')
応答
成功した応答は、HTTP 204 No Content
応答コードで示されます。
通知の API エンティティおよび列挙型
サブスクリプション
基本のサブスクリプションを表します。これは抽象基本クラスです。
基本型:Entity
プロパティ | 型 | 説明 | 書き込み可能 | フィルター処理可能 |
---|---|---|---|---|
リソース | 文字列 | 変更の監視対象となるリソースを指定します。 | はい | 該当なし |
ChangeType | 変更の種類 | 通知を発生させるイベントの種類を示します。サポートされる種類については、ChangeType をご覧ください。 | はい | 該当なし |
通知
クライアントに送られる通知を表します。プッシュ通知の場合、通知はクライアントで指定されたリスナー サービスに送られます。
基本型:Entity
プロパティ | 型 | 説明 | 書き込み可能 | フィルター処理可能 |
---|---|---|---|---|
サブスクリプション | 文字列 | サブスクリプションの一意の識別子です。 | いいえ | いいえ |
サブスクリプションの有効期限 | EDM 日時オフセット | 通知サブスクリプションの有効期限が切れる日時を指定します。時刻は UTC です。 | はい | 該当なし |
SequenceNumber | int32 | 変更通知のシーケンス値を示します。 | いいえ | 該当なし |
ChangeType | 変更の種類 | 通知を発生させたイベントの種類を示します。列挙値は次のとおりです。作成 =1、更新=2、削除=4、失敗=16。通知の失敗は、通知サービスが要求された通知を送信できない場合に発生します。 | いいえ | 該当なし |
リソース | 文字列 | 変更の監視対象となっているリソース アイテムを指定します。 | はい | 該当なし |
リソース データ | エンティティ | 変更されたエンティティを識別します。これはナビゲーションのプロパティです。 | いいえ | 該当なし |
プッシュ通知のサブスクリプション
プッシュ通知の機構を使用するサブスクリプションを表します。
基本型:Subscription
プロパティ | 型 | 説明 | 書き込み可能 | フィルター処理可能 |
---|---|---|---|---|
通知 URL | 文字列 | プッシュ通知を受け取るアプリケーションの URL です。 | はい | 該当なし |
SubscriptionExpirationDateTime | EDM 日時オフセット | 通知サブスクリプションの有効期限が切れる日時を指定します。時刻は UTC です。 | はい | 該当なし |
クライアントの状態 | 文字列 | 通知ごとにサービスによって送信される ClientState ヘッダーの値を指定します。最大の長さは 255 文字です。クライアントはサービスから通知が送られたことを確認できます。これは、ClientState プロパティに設定されている値と、各通知と共に受信された ClientState ヘッダーの値を比較することによって行います。 | はい | いいえ |
変更の種類
通知を発生させることのできるサポートされているリソースに対して発生するイベントの種類を指定する列挙型。
サポートされている値:
- 承認
- 作成済み
- 削除済み
- Missed。
Missed
通知は、通知サービスが要求された通知を送信できない場合に発生します。 - 更新済み
次の手順
アプリケーション開発を開始する準備ができている方にも、単に詳しい情報を必要としている方にも、最適なコンテンツをご用意しています。
- メール、予定表、および連絡先 REST API の使用を開始します。
- サンプルについては、こちらをご覧ください。
Office 365 プラットフォームの使い方の詳細については、次のリンク先をご覧ください。