/*
* Zernio API
*
* API reference for Zernio. Authenticate with a Bearer API key. Base URL: https://zernio.com/api
*
* The version of the OpenAPI document: 1.0.4
* Contact: support@zernio.com
* Generated by: https://openapi-generator.tech
*/
use crate::models;
use serde::{Deserialize, Serialize};
/// WebhookPayloadMessageMetadataReferral : Ad-click attribution forwarded verbatim from Meta. Populated only on the FIRST inbound message after the click; absent on subsequent messages of the same conversation. The populated subset identifies the source platform: - `ctwa_clid` and `source_*` fields: WhatsApp CTWA (Click-to-WhatsApp). Attribution window is 7 days from click. Forward to Meta Conversions API for Business Messaging replay. - `ad_id` and `ads_context_data`: Facebook Messenger CTM (Click-to-Message) or Instagram CTD (Click-to-Direct). Use `ad_id` to attribute the conversation to a specific ad.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct WebhookPayloadMessageMetadataReferral {
/// Meta's GCLID-equivalent click identifier.
#[serde(rename = "ctwa_clid", skip_serializing_if = "Option::is_none")]
pub ctwa_clid: Option<String>,
#[serde(rename = "source_id", skip_serializing_if = "Option::is_none")]
pub source_id: Option<String>,
#[serde(rename = "source_type", skip_serializing_if = "Option::is_none")]
pub source_type: Option<String>,
#[serde(rename = "source_url", skip_serializing_if = "Option::is_none")]
pub source_url: Option<String>,
#[serde(rename = "headline", skip_serializing_if = "Option::is_none")]
pub headline: Option<String>,
#[serde(rename = "body", skip_serializing_if = "Option::is_none")]
pub body: Option<String>,
#[serde(rename = "media_type", skip_serializing_if = "Option::is_none")]
pub media_type: Option<String>,
#[serde(rename = "image_url", skip_serializing_if = "Option::is_none")]
pub image_url: Option<String>,
#[serde(rename = "video_url", skip_serializing_if = "Option::is_none")]
pub video_url: Option<String>,
#[serde(rename = "thumbnail_url", skip_serializing_if = "Option::is_none")]
pub thumbnail_url: Option<String>,
/// Facebook Messenger CTM / Instagram CTD only. The Meta ad ID the user clicked to start the conversation.
#[serde(rename = "ad_id", skip_serializing_if = "Option::is_none")]
pub ad_id: Option<String>,
/// Optional `ref` parameter passed through from the Meta ad creative. Facebook Messenger CTM / Instagram CTD only.
#[serde(rename = "ref", skip_serializing_if = "Option::is_none")]
pub r#ref: Option<String>,
/// Meta-supplied source identifier (e.g. `ADS`). Facebook Messenger CTM / Instagram CTD only.
#[serde(rename = "source", skip_serializing_if = "Option::is_none")]
pub source: Option<String>,
/// Meta-supplied referral type (e.g. `OPEN_THREAD`). Facebook Messenger CTM / Instagram CTD only.
#[serde(rename = "type", skip_serializing_if = "Option::is_none")]
pub r#type: Option<String>,
#[serde(rename = "ads_context_data", skip_serializing_if = "Option::is_none")]
pub ads_context_data: Option<Box<models::WebhookPayloadMessageMetadataReferralAdsContextData>>,
}
impl WebhookPayloadMessageMetadataReferral {
/// Ad-click attribution forwarded verbatim from Meta. Populated only on the FIRST inbound message after the click; absent on subsequent messages of the same conversation. The populated subset identifies the source platform: - `ctwa_clid` and `source_*` fields: WhatsApp CTWA (Click-to-WhatsApp). Attribution window is 7 days from click. Forward to Meta Conversions API for Business Messaging replay. - `ad_id` and `ads_context_data`: Facebook Messenger CTM (Click-to-Message) or Instagram CTD (Click-to-Direct). Use `ad_id` to attribute the conversation to a specific ad.
pub fn new() -> WebhookPayloadMessageMetadataReferral {
WebhookPayloadMessageMetadataReferral {
ctwa_clid: None,
source_id: None,
source_type: None,
source_url: None,
headline: None,
body: None,
media_type: None,
image_url: None,
video_url: None,
thumbnail_url: None,
ad_id: None,
r#ref: None,
source: None,
r#type: None,
ads_context_data: None,
}
}
}