POST スキーマ
Webhook に送信される POST リクエストは、次のスキーマの JSON 形式になります。
Webhook Proto ペイロード
// Represent user lead data for single column
message UserLeadColumnData {
// Human-readable text of the field type (e.g.: Full Name, What is your
// preferred dealership?). This field might not always be populated.
optional string column_name = 1;
// Column value based on column type
oneof column_value {
string string_value = 2;
}
// Column ID. Populated for all types of fields. (e.g.: FULL_NAME)
optional string column_id = 3;
}
// Message to construct webhook JSON payload
message WebhookLead {
// Unique ID to represent lead
optional string lead_id = 1;
// User inputted data per column
repeated UserLeadColumnData user_column_data = 2;
// API version
optional string api_version = 3;
// Form ID to which lead belonged to.
optional int64 form_id = 4;
// Campaign ID that the lead form is associated with
optional int64 campaign_id = 5;
// Key to be used by advertiser to verify the request
// is from Google.
optional string google_key = 6;
// Denotes if the lead is a test lead.
optional bool is_test = 7;
// Click ID for the lead submission.
optional string gcl_id = 8;
// Adgroup ID which generated the lead.
optional int64 adgroup_id = 9;
// Creative ID which generated the lead.
optional int64 creative_id = 10;
// Asset group ID represents the container for holding assets, associated
// URLs, hints and criteria that will be used to select assets and for
// optimization. This field is only populated for Performance Max campaigns.
int64 asset_group_id = 11;
// Lead stage at the time of delivery.
string lead_stage = 12 [(datapol.semantic_type) = ST_NOT_REQUIRED];
// Lead submit time in ISO-8601 format. Ex- 2024-09-26T12:30:00Z
string lead_submit_time = 13 [(datapol.semantic_type) = ST_NOT_REQUIRED];
}
フィールドの説明
フィールド | 説明 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
lead_id |
特定のリードを識別する一意の文字列。 処理の推奨事項: 受信した見込み顧客の重複を排除するために使用します。これは、すべてのフォームで一意になります。特定のリードに関連する問題を報告する場合は、この ID が必要になります。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
api_version |
この見込み顧客スキーマが属する API バージョン。これは新しいスキーマへの移行時に使用されます。現時点では無視できます。 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
form_id |
Google 広告で設定した各フォームの一意の ID。現在のプロダクトでは、キャンペーン単位でフォームを適用できます(広告グループ単位または広告単位で適用するのではなく)。 影響: 見込み顧客は クライアントは 8 バイトの整数を使用して処理する必要があります。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
campaign_id |
関連付けられている見込み顧客フォームの Google 広告キャンペーン ID または広告申込情報 ID(ディスプレイ&ビデオ 360)。 クライアントは 8 バイトの整数を使用して処理する必要があります。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
adgroup_id |
Google 広告の広告グループ ID は、キャンペーン内の特定の広告グループを区別するために使用されます。(動画広告とディスカバリー広告からの見込み顧客にのみ利用可能)
クライアントは 8 バイトの整数を使用して処理する必要があります。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
creative_id |
Google 広告のクリエイティブ ID は、広告グループ内の特定のクリエイティブを区別するために使用されます。(動画広告とディスカバリー広告からの見込み顧客にのみ利用可能) クライアントは 8 バイトの整数を使用して処理する必要があります。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
gcl_id |
Google クリック ID: 広告の各クリックをトラッキングするために使用される一意のパラメータです。 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
google_key |
広告主が各フォームで設定したキー。
推奨される処理: webhook で受信した見込み顧客を処理する前に、 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
is_test |
このフィールドのセマンティクスは「省略可」です。値が true の場合、この見込み顧客をテスト見込み顧客として扱います。値が false の場合、またはフィールドが存在しない場合、この見込み顧客を有効な製品見込み顧客として扱います。 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
user_column_data |
ユーザーが送信したデータを送信する繰り返し Key-Value タプル。
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
asset_group_id |
このフィールドに値が入力されるのは、P-MAX キャンペーンの場合のみです。
これは、見込み顧客フォームを含むコンテナ ID を示します。 クライアントは 8 バイトの整数を使用して処理する必要があります。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
lead_stage |
これは、見込み顧客の提供時点での見込み顧客の段階を示します。このフィールドは、見込み顧客のファネル ステージやコンバージョン ステータスの追跡に役立ちます。 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
lead_submit_time |
ユーザーがフォームを送信したタイムスタンプを示します。ISO-8601 形式で指定します。例: 2024-09-26T12:30:00Z |
認識されないフィールドと上位互換性
Webhook 統合の堅牢性を維持し、将来の機能強化に対応できるようにするには、システムが明示的に使用または認識しない Webhook ペイロード内のフィールドを適切に無視するように JSON パーサーを設計するのが標準的なベスト プラクティスです。
主な推奨事項: アプリケーションに特に必要なフィールドのみを処理するように、JSON 解析ロジックを構成します。固定のフィールドセットを想定したコードや、予期しない新しいフィールドがペイロードに存在する場合に失敗するコードは作成しないでください。
重要な理由:
- 将来の互換性: より豊富なデータや新機能を提供するために、今後のアップデートで Webhook ペイロードに新しいオプション フィールドが追加される場合があります。パーサーが厳格すぎる場合(未知のプロパティで失敗するなど)、Google によってこのような破壊的でない変更がロールアウトされると、統合が中断する可能性があります。
- メンテナンスの簡素化: 積極的に使用するデータポイントのみに焦点を当てることで、統合コードをシンプルに保ち、メンテナンスが容易になります。
最新の JSON 解析ライブラリのほとんどには、不明なプロパティをデフォルトで無視するオプションが用意されています。また、無視するように構成することもできます。
セールスリードのハンドリング
見込み顧客ハンドラは、次の HTTP コードで応答する必要があります。
HTTP レスポンス | レスポンスの本文(JSON) | 再試行可能なエラーですか? |
---|---|---|
200 |
{} | なし |
4XX |
{"message: リクエストの問題を説明する自由形式のエラー テキスト"} | いいえ |
5XX |
{"message: 断続的に発生する取り消し可能なエラーのオプション メッセージ"} | ○ |
重複
1 件のリードを確実に 1 回だけ配信できるとは限りません。そのため、リード処理の Webhook は重複を適切に処理する必要があります。