<ph type="x-smartling-placeholder"></ph>
現在、Apigee Edge のドキュメントが表示されています。
Apigee X のドキュメント。 詳細
はじめに
収益化には、通知設定のテストに使用できる一連の API が用意されています。 具体的には、以下のことができます。
- Webhook の実行をテストして通知が機能することを確認する 送信しています
- 送信された通知を確認して再処理する
Webhook のテスト
Webhook は、イベントによってトリガーされる HTTP コールバック ハンドラを定義します。詳細情報 Webhook の設定について詳しくは、こちら Webhook をご覧ください。
次の手順で Webhook をテストできます。
利用可能な Webhook 通知トリガータイプの表示
利用可能な Webhook 通知トリガーのタイプを確認するには、GET リクエストを 次のリソースをご覧ください。
/organizations/{org_name}/webhooks/{webhook_id}/test/{developer_email_or_id}/{app_id}/{product_id}/{rateplan_id}
ここで
{org_name}には組織の名前を指定します。{webhook_id}には、Webhook の ID を指定します。Webhook のリストを表示するには、 詳細は、「Webhook を使用してすべての Webhook を表示する」 API。{developer_email_or_id}にはデベロッパーの ID を指定します。リストを表示するには、 については、リスト デベロッパー。{app_id}には、Webhook をテストするアプリケーションの ID を指定します。 トリガーされます組織内のアプリ ID を一覧表示するには、 組織。{product_id}には、テストする API プロダクトの ID を指定します。 Webhook トリガーです組織の API プロダクトの一覧を表示するには、API プロダクトの一覧表示をご覧ください。{rateplan_id}には、テストする料金プランの ID を指定します。 Webhook トリガーです料金プラン ID は表示名とは異なります。料金プランを表示するには ID などの詳細については、をご覧ください。 [料金プラン] ページを確認する。
たとえば、次の cURL 呼び出しでは、Webhook として RATEPLANQUOTAUSAGE が返されます。
通知トリガーのタイプを指定します。
curl -H "Content-Type: application/json" -X GET \ "https://api.enterprise.apigee.com/v1/mint/organizations/myorg/webhooks/0a07eb1f-f485-4539-8beb-01be449699b3/test/joe@example.com/e759c119-510c-49a8-886c-f184091944bd/myproduct/mypackage_anrp" \ -u email:password
レスポンスの例を次に示します。
[ "RATEPLANQUOTAUSAGE" ]
次に、Webhook 通知のリクエスト ペイロードのスキーマを決定する必要があります。 トリガーのタイプを指定します。
Webhook 通知のサンプル リクエスト ペイロードの表示 テスト
次のトークンを発行して、Webhook 通知のテストに使用できるサンプル リクエスト ペイロードを確認します。 GET リクエストを次のリソースに送信します。
/organizations/{org_name}/webhooks/{webhook_id}/test/{developer_email_or_id}/{app_id}/{product_id}/{rateplan_id}/{trigger_type}
ここで
{org_name}には組織の名前を指定します。{webhook_id}には、Webhook の ID を指定します。Webhook のリストを表示するには、 詳細は、「Webhook を使用してすべての Webhook を表示する」 API。{developer_email_or_id}にはデベロッパーの ID を指定します。リストを表示するには、 については、リスト デベロッパー。{app_id}には、Webhook をテストするアプリケーションの ID を指定します。 トリガーされます組織内のアプリ ID を一覧表示するには、 組織。{product_id}には、テストする API プロダクトの ID を指定します。 Webhook トリガーです組織の API プロダクトの一覧を表示するには、API プロダクトの一覧表示をご覧ください。{rateplan_id}には、テストする料金プランの ID を指定します。 Webhook トリガーです料金プラン ID は表示名とは異なります。料金プランを表示するには ID などの詳細については、をご覧ください。 [料金プラン] ページを確認する。{trigger_type}には、Webhook 通知トリガータイプの名前を指定します。 (利用可能な Webhook をリスト 通知トリガータイプ)。
たとえば、次の cURL 呼び出しでは、サンプルのリクエスト ペイロードが
RATEPLANQUOTAUSAGE Webhook 通知のトリガータイプ:
curl -H "Content-Type: application/json" -X GET \ "https://api.enterprise.apigee.com/v1/mint/organizations/myorg/webhooks/0a07eb1f-f485-4539-8beb-01be449699b3/test/joe@example.com/e759c119-510c-49a8-886c-f184091944bd/myproduct/mypackage_anrp/RATEPLANQUOTAUSAGE" \ -u email:password
リクエスト ペイロードの例を次に示します。
{
"eventTriggerReason": "RATEPLANQUOTAUSAGE",
"properties": [
{
"key": "quotaPercentUsed",
"value": "100"
}
]
}
次に、返されたサンプル リクエストのペイロードを必要に応じて変更し、それを使用して Webhook の実行です
Webhook の実行をテストする
次のリソースに POST リクエストを発行して、Webhook の実行をテストします。
/organizations/{org_name}/webhooks/{webhook_id}/test/{developer_email_or_id}/{app_id}/{product_id}/{rateplan_id}。
ここで
{org_name}には組織の名前を指定します。{webhook_id}には、Webhook の ID を指定します。Webhook のリストを表示するには、 詳細は、「Webhook を使用してすべての Webhook を表示する」 API。{developer_email_or_id}にはデベロッパーの ID を指定します。リストを表示するには、 については、リスト デベロッパー。{app_id}には、Webhook をテストするアプリケーションの ID を指定します。 トリガーされます組織内のアプリ ID を一覧表示するには、 組織。{product_id}には、テストする API プロダクトの ID を指定します。 Webhook トリガーです組織の API プロダクトの一覧を表示するには、API プロダクトの一覧表示をご覧ください。{rateplan_id}には、テストする料金プランの ID を指定します。 Webhook トリガーです料金プラン ID は表示名とは異なります。料金プランを表示するには ID などの詳細については、をご覧ください。 [料金プラン] ページを確認する。
前のステップ(Webhook 通知テスト用のサンプル リクエスト ペイロードを表示する)で返されたサンプル リクエスト ペイロードを次のように変更します。 リクエスト ペイロードで渡します。
たとえば、次の cURL 呼び出しでは、指定された Webhook の実行をテストします。
curl -H "Content-Type: application/json" -X POST -d \
'{
"eventTriggerReason": "RATEPLANQUOTAUSAGE",
"properties": [
{
"key": "quotaPercentUsed",
"value": "120"
}
]
}' \
"https://api.enterprise.apigee.com/v1/mint/organizations/myorg/webhooks/0a07eb1f-f485-4539-8beb-01be449699b3/test/joe@example.com/e759c119-510c-49a8-886c-f184091944bd/myproduct/mypackage_anrp" \
-u email:password
通知が送信されたことを示すレスポンスの例を次に示します。 Webhook に送信します。
{
"original": {
"createdDate": 1463619959930,
"createdTimeStamp": 1463616000000,
"notificationType": "WEBHOOK",
"orgId": "myorg",
"rawMessage": "{\"orgName\":\"myorg\",\"developerEmail\":\"joe@example.com\",\"developerFirstName\":\"Joe\",\"developerLastName\":\"Smith\",\"applicationName\":\"myapp\",\"packageName\":\"MyPackage\",\"packageId\":\"mypackage\",\"ratePlanId\":\"mypackage_anrp\",\"ratePlanName\":\"anrp\",\"ratePlanType\":\"STANDARD\",\"developerRatePlanQuotaTarget\":200,\"quotaPercentUsed\":\"120\",\"ratePlanStartDate\":1463616000000,\"ratePlanEndDate\":null,\"nextBillingCycleStartDate\":null,\"products\":[\"myproduct\"],\"developerCustomAttributes\":[]\"triggerTime\":1463619959929,\"triggerReason\":\"RATEPLANQUOTAUSAGE\",\"developerQuotaResetDate\":null}",
"retryCount": 0,
"retryStatuses": [],
"source": "MailTo: [36112720-1304-4e0b-9b17-991f5e121ebb], Org: [myorg], TransactionId: [], LimitId: [], Key: []",
"toEmail": "http://123.45.67.89/webhook",
"updatedDate": 1463619959930
},
"raw": "This is the response",
"responseCode": 200,
"status": "NOTIFICATION_SENT"
}
通知の表示と再処理
収益化では、特定のイベントによってトリガーされる通知を設定できます。対象 通知の設定について詳しくは、通知を設定するをご覧ください。
送信された通知ごとに、次の情報が保存されます。
- 再試行回数
- レスポンス コード
- レスポンス ヘッダー
- レスポンスの内容(最初の 1,000 文字のみ)
通知を表示して再処理する手順は次のとおりです。
送信された通知の表示
組織に対して送信された通知を表示するには、GET リクエストを 次のリソースをご覧ください。
/organizations/{org_name}/notification-service-items
ここで、{org_name} には組織の名前を指定します。
必要に応じて、次のクエリ パラメータを 1 つ以上指定してリストをフィルタリングできます。 レスポンスで返される通知の数:
| クエリ パラメータ | 説明 |
|---|---|
startdate |
開始日は YYYY-MM-DD HH:mm:ss の形式で指定します。 |
enddate |
終了日。形式は YYYY-MM-DD HH:mm:ss です。 |
status |
通知のステータス。有効な値は次のとおりです。
<ph type="x-smartling-placeholder">
|
toemail |
通知の送信先メール ID または Webhook。 |
最大 1,000 件の通知が返されます。
レスポンスの hasMoreItems フラグは、レスポンスのリクエスト数
通知の合計数が 1,000 件を超えています。hasMoreItems が
true は、表示可能な数を超える通知があることを示します。
残りの通知を表示するには、クエリ パラメータのフィルタを絞り込む必要があります
リクエストごとに小さな通知グループを
処理できますたとえば、1 つの行に複数の
リクエストの範囲を狭くしたり、特定のステータスの通知のみを返したりする
使用できます。
たとえば、次の cURL 呼び出しでは、指定したルールで失敗した通知がリストされます。 Webhook を作成します。
curl -H "Content-Type: application/json" -X GET \ "https://api.enterprise.apigee.com/v1/mint/organizations/myorg/notification-service-items?enddate=2016-05-19 12:00:00&startdate=2016-05-18 12:00:00&status=FAILED&toemail=http://123.45.6789:8000/webhook" \ -u email:password
レスポンスの例を次に示します。
{
"hasMoreItems": false,
"notifications": [
{
"createdDate": 1463626865974,
"createdTimeStamp": 1463616000000,
"id": "9d87c6ea-1394-495b-bfb7-1d2e7ef3f837",
"notificationType": "WEBHOOK",
"orgId": "Org_d40f6c2e-1d6d-11e6-a4ed-af8444f24e4f",
"rawMessage": "{\"orgName\":\"Org_d40f6c2e-1d6d-11e6-a4ed-af8444f24e4f\",\"developerEmail\":\"joe@example.com\",\"developerFirstName\":\"Joe\",\"developerLastName\":\"Smith\",\"applicationName\":\"MyApp\",
\"packageName\":\"test-package\",\"packageId\":\"myorg@@@test-package-9ubo\",\"ratePlanId\":\"myorg@@@test-package-9ubo_anrp\",\"ratePlanName\":\"anrp\",\"ratePlanType\":\"STANDARD\",
\"developerRatePlanQuotaTarget\":10,\"quotaPercentUsed\":\"20\",\"ratePlanStartDate\":1463616000000,\"ratePlanEndDate\":null,\"nextBillingCycleStartDate\":1464739200000,\"products\":[\"product1\"],
\"developerCustomAttributes\":[],\"triggerTime\":1463626865907,\"triggerReason\":\"RatePlanQuotaUsage\",\"developerQuotaResetDate\":\"1464810145000\"}",
"retryCount": 3,
"retryStatuses": [
{
"responseCode": 500,
"responseMessage": "{\"Headers\":\"[{\"name\":\"Content-length\",\"buffer\":{\"empty\":false,\"full\":false},\"valuePos\":15,\"value\":\"20\",\"elements\":[{\"name\":\"20\",\"value\":null,\"parameters\":[],\"parameterCount\":0}]},{\"name\":\"Date\",\"buffer\":{\"empty\":false,\"full\":false},\"valuePos\":5,\"value\":\"Thu, 19 May 2016 03:01:09 GMT\",\"elements\":[{\"name\":\"Thu\",\"value\":null,\"parameters\":[],\"parameterCount\":0},{\"name\":\"19 May 2016 03:01:09 GMT\",\"value\":null,\"parameters\":[],\"parameterCount\":0}]}]\",\"StatusCode\":\"500\",\"Content : \":\"This is the response\"}",
"retriedAt": 1463626869184,
"retryAttempt": 1
},
{
"responseCode": 500,
"responseMessage": "{\"Headers\":\"[{\"name\":\"Content-length\",\"buffer\":{\"empty\":false,\"full\":false},\"valuePos\":15,\"value\":\"20\",\"elements\":[{\"name\":\"20\",\"value\":null,\"parameters\":[],\"parameterCount\":0}]},{\"name\":\"Date\",\"buffer\":{\"empty\":false,\"full\":false},\"valuePos\":5,\"value\":\"Thu, 19 May 2016 03:01:09 GMT\",\"elements\":[{\"name\":\"Thu\",\"value\":null,\"parameters\":[],\"parameterCount\":0},{\"name\":\"19 May 2016 03:01:09 GMT\",\"value\":null,\"parameters\":[],\"parameterCount\":0}]}]\",\"StatusCode\":\"500\",\"Content : \":\"This is the response\"}",
"retriedAt": 1463626869318,
"retryAttempt": 2
},
{
"responseCode": 500,
"responseMessage": "{\"Headers\":\"[{\"name\":\"Content-length\",\"buffer\":{\"empty\":false,\"full\":false},\"valuePos\":15,\"value\":\"20\",\"elements\":[{\"name\":\"20\",\"value\":null,\"parameters\":[],\"parameterCount\":0}]},{\"name\":\"Date\",\"buffer\":{\"empty\":false,\"full\":false},\"valuePos\":5,\"value\":\"Thu, 19 May 2016 03:01:09 GMT\",\"elements\":[{\"name\":\"Thu\",\"value\":null,\"parameters\":[],\"parameterCount\":0},{\"name\":\"19 May 2016 03:01:09 GMT\",\"value\":null,\"parameters\":[],\"parameterCount\":0}]}]\",\"StatusCode\":\"500\",\"Content : \":\"This is the response\"}",
"retriedAt": 1463626869378,
"retryAttempt": 3
}
],
"source": "MailTo: [6c3cde37-a8f1-4077-adbe-e9f6605a7299], Org: [myorg], TransactionId: [b8d763be-7185-450d-b421-df38c870fabd], LimitId: [RatePlan-Limit:myorg@@@test-package-9ubo_anrp], Key: [myorg@@@kjGSxEGtZeekBEyI~myorg@@@test-package-9ubo_anrp~Transactions~Calls~20]",
"status": "FAILED",
"toEmail": "http://123.45.67.89:8000/webhook",
"updatedDate": 1463626865974
}
]
}
通知の詳細の表示
特定の通知の詳細を表示するには、次に対して GET リクエストを発行します。 resource:
/organizations/{org_name}/notification-service-items/{notification_id}
ここで
{org_name}には組織の名前を指定します。{notification_id}には、確認する通知の ID を指定します。 表示されます。通知 ID は、送信された通知を表示するときに、レスポンス出力から取得できます。
たとえば、次の cURL 呼び出しでは、次の ID を持つ通知の詳細がリストされます。
4b3dfadf-3a96-4a92-9512-1feff22f74f3:
curl -H "Content-Type: application/json" -X GET \ "https://api.enterprise.apigee.com/v1/mint/organizations/myorg/notification-service-items/faa8e6a8-754e-40e8-9e0c-4dee6c9aca23" \ -u email:password
レスポンスの例を次に示します。
{
"createdDate": 1461062402871,
"createdTimeStamp": 1461024000000,
"id": "faa8e6a8-754e-40e8-9e0c-4dee6c9aca23",
"notificationType": "WEBHOOK",
"orgId": "myorg",
"rawMessage": "{\"orgName\":\"myorg\",\"developerEmail\":\"joe@example.com\",\"developerFirstName\":\"Joe\",\"developerLastName\":\"Smith\",\"applicationName\":\"myapp\",\"packageName\":\"mypackage\",\"ratePlanName\":\"anrp\",\"ratePlanType\":\"STANDARD\",\"developerRatePlanQuotaTarget\":54000,\"quotaPercentUsed\":\"1\",\"ratePlanStartDate\":1460419200000,\"ratePlanEndDate\":null,\"nextBillingCycleStartDate\":null,\"products\":[\"myproduct\"],\"developerCustomAttributes\":[],\"triggerTime\":1461062395966,\"triggerReason\":\"RatePlanQuotaUsage\"}",
"retryCount": 0,
"retryStatuses": [],
"source": "MailTo: [c9e42fcd-9632-4376-b92d-0fa27f178a3b], Org: [myorg], TransactionId: [0352e568-2724-42d9-a264-1b62586d5948], LimitId: [RatePlan-Limit:amyorg@@@mypackage-a0y9_anrp], Key: [myorg@@@PPXsQbkyO1bBhQOh~myorg@@@mypackage-a0y9_anrp~Transactions~Calls~1]",
"status": "NOTIFICATION_SENT",
"toEmail": "http://123.45.67.89:8000/webhook",
"updatedDate": 1461062402871
}
通知の再処理
POST リクエストを次のリソースに発行して、通知を再処理します。
/organizations/{org_name}/notification-service-items/{notification_id}/reprocess
ここで
{org_name}には組織の名前を指定します。{notification_id}には、必要な通知アイテムの ID を指定します。 詳細を表示します。通知 ID は、送信された通知を表示するときに、レスポンス出力から取得できます。
たとえば、次の cURL 呼び出しは、ID が含まれる通知を再処理します。
4b3dfadf-3a96-4a92-9512-1feff22f74f3:
curl -H "Content-Type: application/json" -X POST \ "https://api.enterprise.apigee.com/v1/mint/organizations/myorg/notification-service-items/faa8e6a8-754e-40e8-9e0c-4dee6c9aca23/reprocess" \ -u email:password
{
"createdDate": 1461062402871,
"createdTimeStamp": 1461024000000,
"id": "faa8e6a8-754e-40e8-9e0c-4dee6c9aca23",
"notificationType": "WEBHOOK",
"orgId": "myorg",
"rawMessage": "{\"orgName\":\"myorg\",\"developerEmail\":\"joe@example.com\",\"developerFirstName\":\"Joe\",\"developerLastName\":\"Smith\",\"applicationName\":\"myapp\",\"packageName\":\"mypackage\",\"ratePlanName\":\"anrp\",\"ratePlanType\":\"STANDARD\",\"developerRatePlanQuotaTarget\":54000,\"quotaPercentUsed\":\"1\",\"ratePlanStartDate\":1460419200000,\"ratePlanEndDate\":null,\"nextBillingCycleStartDate\":null,\"products\":[\"myproduct\"],\"developerCustomAttributes\":[],\"triggerTime\":1461062395966,\"triggerReason\":\"RatePlanQuotaUsage\"}",
"retryCount": 0,
"retryStatuses": [
{
"responseCode": 200,
"responseMessage": "{\"Headers\":\"[{\"name\":\"Accept-Encoding\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":16,\"elements\":[{\"name\":\"gzip\",\"value\":null,\"parameters\":[],\"parameterCount\":0},{\"name\":\"deflate\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"gzip,deflate\"},{\"name\":\"Content-Type\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":13,\"elements\":[{\"name\":\"application/json\",\"value\":null,\"parameters\":[{\"name\":\"charset\",\"value\":\"UTF-8\"}],\"parameterCount\":1}],\"value\":\"application/json; charset=UTF-8\"},{\"name\":\"Date\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":5,\"elements\":[{\"name\":\"Mon\",\"value\":null,\"parameters\":[],\"parameterCount\":0},{\"name\":\"23 May 2016 21:46:37 GMT\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"Mon, 23 May 2016 21:46:37 GMT\"},{\"name\":\"Server\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":7,\"elements\":[{\"name\":\"Apigee Router\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"Apigee Router\"},{\"name\":\"User-Agent\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":11,\"elements\":[{\"name\":\"Apache-HttpClient/4.3.5 (java 1.5)\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"Apache-HttpClient/4.3.5 (java 1.5)\"},{\"name\":\"X-Forwarded-For\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":16,\"elements\":[{\"name\":\"54.200.58.80\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"54.200.58.80\"},{\"name\":\"X-Forwarded-Port\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":17,\"elements\":[{\"name\":\"80\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"80\"},{\"name\":\"X-Forwarded-Proto\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":18,\"elements\":[{\"name\":\"http\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"http\"},{\"name\":\"Content-Length\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":15,\"elements\":[{\"name\":\"1173\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"1173\"},{\"name\":\"Connection\",\"buffer\":{\"full\":false,\"empty\":false},\"valuePos\":11,\"elements\":[{\"name\":\"keep-alive\",\"value\":null,\"parameters\":[],\"parameterCount\":0}],\"value\":\"keep-alive\"}]\",\"StatusCode\":\"200\",\"Content : \":\"{\"orgName\":\"myorg\",\"developerEmail\":\"joe@example.com\",\"developerFirstName\":\"Joe\",\"developerLastName\":\"Smith\",\"applicationName\":\"MyApp\",\"packageName\":\"mypackage\",\"ratePlanName\":\"anrp\",\"ratePlanType\":\"STANDARD\",\"developerRatePlanQuotaTarget\":54000,\"quotaPercentUsed\":\"1\",\"ratePlanStartDate\":1460419200000,\"ratePlanEndDate\":null,\"nextBillingCycleStartDate\":null,\"products\":[\"product1\"],\"developerCustomAttributes\":[],
"source": "MailTo: [c9e42fcd-9632-4376-b92d-0fa27f178a3b], Org: [myorg], TransactionId: [0352e568-2724-42d9-a264-1b62586d5948], LimitId: [RatePlan-Limit:amyorg@@@mypackage-a0y9_anrp], Key: [myorg@@@PPXsQbkyO1bBhQOh~myorg@@@mypackage-a0y9_anrp~Transactions~Calls~1]",
"status": "NOTIFICATION_SENT",
"toEmail": "http://123.45.67.89:8000/webhook",
"updatedDate": 1461062402871
}