Webhook - カスタムリクエストの送信 - テンプレート変数ガイド
テンプレート変数を使用して複雑なwebhookを構築する方法を学びます。
前提条件
概要
カスタムリクエストが複雑なペイロード(ネストされたJSONやXMLなど)を必要とする場合、テンプレートオプションを使用して、ベンダーのエンドポイントが必要とする形式でペイロードを構築します。データレイヤーの属性は、カスタムテンプレート変数にマッピングでき、その後、任意のテンプレート内で参照できます。このガイドでは、単一のキー値ペアと配列値の両方のテンプレート変数の作成方法を示します。
単一値変数
テンプレート変数の最も一般的な使用法は、属性から動的な値をテンプレート内のプレースホルダーに渡すことです。テンプレート変数は、その名前を二重中括弧で囲むことで、任意のテンプレートで参照できます。例:{{VARIABLE NAME}}
。
以下は、ショッピングカートのステータスを追跡するために必要なペイロードの例です:
{
"userEmail" : "bob@email.com",
"total" : 9.99,
"discount" : "10%",
"date" : "2016-07-13T12:30:59.000Z"
}
各値は動的であり、対応する属性によって入力される必要があります。このペイロードの各値の名前は、リクエストの形式に対するベンダーの要件です。テンプレート変数は、このようなリクエストに属性値を入力する方法です。
このペイロードを作成するために必要なテンプレートは、以下のようになるかもしれません。ここでは、値が使用するテンプレート変数を参照するプレースホルダーに置き換えられています:
{
"userEmail" : "{{userEmail}}",
"total" : {{itemTotal}},
"date" : "{{date}}",
"discount" : "{{discount}}"
}
テンプレート変数を使用してこれを実現する方法は以下の通りです:
- ボディデータに含めたい属性を特定します。この例では、以下のカートの詳細を使用します:
Data Layer Attribute Type Template Variable Value Cart User Email String userEmail
user@example.com
Cart Total Number itemTotal
9.99
Cart Date Date date
2016-07-13T12:30:59.000Z
Cart Discount String discount
10%
- テンプレート変数セクションで、各属性を選択したテンプレート変数名にマッピングします。
- テンプレートセクションで、ベンダーの仕様に従った適切なテンプレートを構築します。このテンプレートには、後で二重中括弧で参照される有用な名前を付けておくことが重要です。このテンプレートは"cartdetails"と呼ばれます。
- Body Dataセクションで、Custom Valueの
{{cartdetails}}
をBodyにマッピングします。
ネストマップ:1レベルのオブジェクト配列
JSONのオブジェクト配列を構築するには、配列属性と特別な"ドット名"表記法を使用してテンプレート変数の名前を付ける必要があります。この表記法を使用すると、".“の前に来る名前の部分が自動的にその名前で参照されるテンプレート内のセクションの使用を可能にします。この仕組みを理解するための例を見てみましょう。
以下は、ショッピングカートの内容を追跡するために必要なペイロードの例です:
{
"cart": [{
"item" : "Plate",
"quantity": "1",
"price" : "5.00",
"id" : "001"
},
{
"item" : "Fork",
"quantity": "2",
"price" : "0.99",
"id" : "002"
},
{
"item" : "Mug",
"quantity": "1",
"price" : "6.99",
"id" : "003"
}]
}
このようなペイロードを構築するためには、以下のようなテンプレートが必要です:
{
"cart": [
{{#cart}}
{
"item" : "{{item}}",
"quantity" : "{{quantity}}",
"price" : "{{price}}",
"id" : "{{id}}"
}{{#iter.hasNext}}, {{/iter.hasNext}}
{{/cart}}
]
}
この例では、テンプレート変数でドット名を使用してcartをプレフィックスとして使用します。例:cart.item
。
以下に、必要なテンプレート変数の定義方法を示します:
Data Layer Attribute | Type | Template Variable | Value |
---|---|---|---|
Cart Items | Array of Strings | cart.item |
["Plate", "Fork", "Mug"] |
Cart Quantities | Array of Numbers | cart.quantity |
["1", "2", "1"] |
Cart Prices | Array of Numbers | cart.price |
["5.00", "0.99", "6.99"] |
Cart Item IDs | Array of Strings | cart.id |
["001", "002", "003"] |
オブジェクトの配列に対する制限
- ネストされた要素は1レベルまでしかサポートされていません。より深いJSON構造は不可能です。
- データレイヤー属性はすべて同じ長さの配列でなければなりません。
カスケードマップ:オブジェクト全体に値を構成
単一のデータ属性をすべての配列オブジェクトにカスケードすることが可能です。変数名が特別な"ピリオド"文字表記法に従っている限り、すべての非セットオブストリング属性がカスケードされます。
例:
Data Layer Attribute | Attribute Type | Variable | Value |
---|---|---|---|
Cart Items | Set of Strings | cart.item |
[ "Plate", "Fork", "Mug" ] |
Transaction ID | String | cart.transactionId |
T1284 |
結果のJSON:
{
"cart": [
{
"item": "Plate",
"transactionId": "T1284"
},
{
"item": "Fork",
"transactionId": "T1284"
},
{
"item": "Mug",
"transactionId": "T1284"
}
]
}
最終更新日 :: 2025年January月10日