late 0.0.326

API reference for Zernio. Authenticate with a Bearer API key. Base URL: https://zernio.com/api
Documentation
/*
 * 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,
        }
    }
}