/*
* 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};
/// CreateStandaloneAdRequestPlacementAssets : Meta only. Placement asset customization: pin a SPECIFIC asset (image OR video) to each placement group on a SINGLE ad (e.g. a 9:16 on Stories/Reels and a 4:5 on Feed). The same thing Meta Ads Manager produces with \"different creative per placement\", mapped to the creative's `asset_feed_spec` + `asset_customization_rules`. Deterministic pinning, NOT the auto-optimizing pool of `dynamicCreative` (mutually exclusive, and it cannot be combined with `creatives[]` or `adSetId`). Shared copy (headline, body, link, CTA) comes from the top-level single-creative fields since only the asset varies by placement. Each rule's `placements` accepts the same fields as the top-level `placements` object; Meta enforces co-selection rules and returns an actionable error. A block is all-image OR all-video, never mixed (Meta's asset_feed_spec carries one ad format). Image mode: `defaultImageUrl` + `rules[].imageUrl`. Video mode: `defaultVideoUrl` + `rules[].videoUrl` (optional `thumbnailUrl`/`defaultThumbnailUrl` posters; Meta auto-generates when omitted). Exactly one catch-all default is required.
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct CreateStandaloneAdRequestPlacementAssets {
/// Image mode. Catch-all image for any placement no rule matches. Required in image mode (Meta mandates a default rule).
#[serde(rename = "defaultImageUrl", skip_serializing_if = "Option::is_none")]
pub default_image_url: Option<String>,
/// Video mode. Catch-all video for any placement no rule matches. Required in video mode.
#[serde(rename = "defaultVideoUrl", skip_serializing_if = "Option::is_none")]
pub default_video_url: Option<String>,
/// Video mode (optional). Poster image for the default video; Meta auto-generates one when omitted.
#[serde(
rename = "defaultThumbnailUrl",
skip_serializing_if = "Option::is_none"
)]
pub default_thumbnail_url: Option<String>,
/// One entry per placement group you want to pin a specific asset to.
#[serde(rename = "rules")]
pub rules: Vec<models::CreateStandaloneAdRequestPlacementAssetsRulesInner>,
}
impl CreateStandaloneAdRequestPlacementAssets {
/// Meta only. Placement asset customization: pin a SPECIFIC asset (image OR video) to each placement group on a SINGLE ad (e.g. a 9:16 on Stories/Reels and a 4:5 on Feed). The same thing Meta Ads Manager produces with \"different creative per placement\", mapped to the creative's `asset_feed_spec` + `asset_customization_rules`. Deterministic pinning, NOT the auto-optimizing pool of `dynamicCreative` (mutually exclusive, and it cannot be combined with `creatives[]` or `adSetId`). Shared copy (headline, body, link, CTA) comes from the top-level single-creative fields since only the asset varies by placement. Each rule's `placements` accepts the same fields as the top-level `placements` object; Meta enforces co-selection rules and returns an actionable error. A block is all-image OR all-video, never mixed (Meta's asset_feed_spec carries one ad format). Image mode: `defaultImageUrl` + `rules[].imageUrl`. Video mode: `defaultVideoUrl` + `rules[].videoUrl` (optional `thumbnailUrl`/`defaultThumbnailUrl` posters; Meta auto-generates when omitted). Exactly one catch-all default is required.
pub fn new(
rules: Vec<models::CreateStandaloneAdRequestPlacementAssetsRulesInner>,
) -> CreateStandaloneAdRequestPlacementAssets {
CreateStandaloneAdRequestPlacementAssets {
default_image_url: None,
default_video_url: None,
default_thumbnail_url: None,
rules,
}
}
}