Webhook Facebook App Events APIの構成方法
テンプレートとテンプレート変数を使用してWebhook - カスタムリクエストアクションでFacebook App Events APIを構成する方法。
概要
FacebookにHTTPリクエストを送信して、アプリ内の1つ以上のコンバージョンを追跡します。イベントデータはJSONエンコードされた文字列として表現されます。詳細はFacebook App Events APIを参照してください。
API呼び出し例:
curl \
-F "event=CUSTOM_APP_EVENTS" \
-F "advertiser_id=1111-1111-1111-1111" \
-F "advertiser_tracking_enabled=1" \
-F "application_tracking_enabled=1" \
-F "custom_events=[{\"_eventName\":\"fb_mobile_purchase\",
\"_valueToSum\":55.22,
\"_logTime\":1367017882,
\"fb_currency\":\"GBP\",
}]" \
"https://graph.facebook.com/API_VERSION/APP_ID/activities"
提供されたcurlの例(-Fオプション付き)は、リクエストがPOSTメソッドを使用し、そのボディが"multipart/form-data"コンテンツタイプであることを示しています。Webhookで構成できる個々のコンポーネントに分けて全体のリクエストを解析しましょう。
1. APIエンドポイント/URL
https://graph.facebook.com/API_VERSION/APP_ID/activities
この例では、URLにはAPIバージョンとAPP_ID
のプレースホルダー値があります。これらはおそらくURLにハードコーディングできますが、デモンストレーションの目的で、動的な値を使用してこのコンポーネントを作成するURLテンプレートを使用します。
2. シンプルなフォームフィールドの値
event = CUSTOM_APP_EVENTS
advertiser_id = 1111-1111-1111-1111
advertiser_tracking_enabled = 1
application_tracking_enabled = 1
これらのキーと値のペアは、ボディデータセクションのカスタム値を使用してマッピングできるシンプルなフォームフィールドです。
3. JSON値
custom_events = [{ "_eventName" : "fb_mobile_purchase",
"_valueToSum" : 55.22,
"_logTime" : 1367017882,
"fb_currency" : "GBP",
}]
この特定のフィールド名"custom_events"は、より複雑な値、JSON文字列を持っています。この値をWebhookで再現するために、テンプレート変数とテンプレートを使用します。
Webhookの構成
メソッドフィールド
“POST"に構成します。
URLフィールド
{{url_template}}
に構成します。
URLはハードコード(組み込みのAPIバージョンとアプリID付き)でも、テンプレートベースでも構いません。後者のアプローチは、データレイヤー属性の柔軟性を高めるために採用されています。下記のテンプレートセクションを参照してください。
ボディコンテンツタイプ
オプションmultipart/form-data
を選択します。
ボディデータ
例のリクエストから各フィールドの名前/値のペアを構成します。custom_eventsの値は、作成するテンプレートの名前、events_template
であることに注意してください。
Facebookフィールド名 | カスタム値 | コメント |
---|---|---|
event |
CUSTOM_APP_EVENTS |
|
advertiser_id |
1111-1111-1111-1111 |
|
advertiser_tracking_enabled |
1 |
|
application_tracking_enabled |
1 |
|
custom_events |
{{events_template}} |
下記で作成されたテンプレートを参照 |
パラメータ値はこの例ではカスタム/静的な値ですが、動的なデータレイヤー属性として簡単に提供できます。
テンプレート変数
テンプレートで参照され、置換される名前/値のペアを構成します。
テンプレート変数名 | タイプ | 値 | ノート |
---|---|---|---|
name |
カスタム値 | fb_mobile_purchase |
|
currency |
カスタム値 | USD |
|
logTime |
Data Attribute | 現在の時間 | 1468358987 |
eventSums.value |
Set of Strings Attribute | FBイベント合計 | ドット命名規則はテンプレート内の一致するセクションを作成します。配列値: [0.99, 4.99] |
apiVersion |
カスタム値 | `v2.6 | URLテンプレートで使用するため |
appId |
カスタム値 | 123456 |
URLテンプレートで使用するため |
テンプレート
URLとcustom_eventsパラメータに割り当てるためのJSON値の2つのテンプレートを作成します。テンプレートは、波括弧の構文を使用してテンプレート変数を使用することに注意してください。
このテンプレートは、“eventSums.value"変数に基づいており、これは文字列のセット属性によって入力されます。これは配列属性なので、テンプレートはテンプレート変数名のプレフィクス(この場合は"eventSums”)のセクションを作成します。
url_template:
https://graph.facebook.com/{{apiVersion}}/{{appId}}/activities
events_template:
[
{{#eventSums}}
{
"_eventName" : "{{name}}",
"_valueToSum" : {{value}},
"_logTime" : {{logTime.toTimestamp}},
"fb_currency" : "{{currency}}"
}{{#iter.hasNext}}, {{/iter.hasNext}}
{{/eventSums}}
]
レンダリングされたテンプレート
テンプレートはレンダリングされ、その内容はWebhook構成のどこでも参照されます(この例では、URLとBody Dataのcustom_events
フィールド)。
_valueToSum
パラメータは、文字列のセット属性から値を受け取ることに注意してください。
url_template:
https://graph.facebook.com/v2.6/12345/activities
events_template:
[
{
"_eventName" : "fb_mobile_purchase",
"_valueToSum" : 0.99,
"_logTime" : 1468358987,
"fb_currency" : "USD"
},
{
"_eventName" : "fb_mobile_purchase",
"_valueToSum" : 4.99,
"_logTime" : 1468358987,
"fb_currency" : "USD"
}
]
最終更新日 :: 2025年January月10日