Utiliser les types de tampons de protocole

<ph type="x-smartling-placeholder">

Étant donné que l'API Google Ads utilise Protobuf comme format de charge utile par défaut, il est important pour comprendre quelques conventions et types Protobuf lorsque vous travaillez avec l'API.

Champs facultatifs

Dans l'API Google Ads, de nombreux champs sont marqués comme optional. Cela vous permet distinguer les cas où le champ a une valeur vide et le serveur n'a pas renvoyé de valeur pour le champ. Ces champs se comportent comme des , sauf qu'ils fournissent également des méthodes supplémentaires pour effacer le champ et pour vérifiez si le champ est défini.

Par exemple, le champ Name de l'objet Campaign est marqué comme facultatif. Vous pouvez donc utiliser les méthodes suivantes pour travailler avec ce champ.

// Get the name.
string name = campaign.Name;

// Set the name.
campaign.Name = name;

// Check if the campaign object has the name field set.
bool hasName = campaign.HasName();

// Clear the name field. Use this method to exclude Name field from
// being sent to the server in a subsequent API call.
campaign.ClearName();

// Set the campaign to empty string value. This value will be
// sent to the server if you use this object in a subsequent API call.
campaign.Name = "";

// This will throw a runtime error. Use ClearName() instead.
campaign.Name = null;

Types répétés

Dans l'API Google Ads, un tableau de champs est représenté sous la forme d'un tableau RepeatedField

Par exemple, le champ url_custom_parameters d'une campagne est un champ répété. Il est donc représenté par une RepeatedField<CustomParameter> en lecture seule dans bibliothèque cliente.

Le RepeatedField implémente la IList<T> de commande.

Il existe deux façons de renseigner un champ RepeatedField.

Ancienne version de C# : ajouter des valeurs à l'aide de la méthode AddRange

Vous en trouverez un exemple ci-dessous.

Campaign campaign = new Campaign()
{
    ResourceName = ResourceNames.Campaign(customerId, campaignId),
    Status = CampaignStatus.Paused,
};

// Add values to UrlCustomParameters using AddRange method.
campaign.UrlCustomParameters.AddRange(new CustomParameter[]
{
    new CustomParameter { Key = "season", Value = "christmas" },
    new CustomParameter { Key = "promocode", Value = "NY123" }
});

Versions plus récentes de C# : utiliser la syntaxe de l'initialiseur de collection

// Option 1: Initialize the field directly.
Campaign campaign = new Campaign()
{
    ResourceName = ResourceNames.Campaign(customerId, campaignId),
    Status = CampaignStatus.Paused,
    // Directly initialize the field.
    UrlCustomParameters =
    {
        new CustomParameter { Key = "season", Value = "christmas" },
        new CustomParameter { Key = "promocode", Value = "NY123" }
    }
};

// Option 2: Initialize using an intermediate variable.
CustomParameter[] parameters = new CustomParameter[]
{
    new CustomParameter { Key = "season", Value = "christmas" },
    new CustomParameter { Key = "promocode", Value = "NY123" }
}

Campaign campaign1 = new Campaign()
{
    ResourceName = ResourceNames.Campaign(customerId, campaignId),
    Status = CampaignStatus.Paused,
    // Initialize from an existing array.
    UrlCustomParameters = { parameters }
};

OneOf de type

Certains champs de l'API Google Ads sont marqués en tant que champs OneOf, ce qui signifie que le champ peut contenir différents types, mais une seule valeur à la fois. Les champs OneOf sont similaire au type d'union en C.

La bibliothèque .NET implémente les champs OneOf en fournissant une propriété pour chaque type. pouvant être contenues dans un champ OneOf, et toutes les propriétés mettant à jour un partagé.

Par exemple, le campaign_bidding_strategy de la campagne est marqué comme OneOf . Cette classe est implémentée comme suit (code simplifié par souci de concision):

public sealed partial class Campaign : pb::IMessage<Campaign>
{
    object campaignBiddingStrategy_ = null;
    CampaignBiddingStrategyOneofCase campaignBiddingStrategyCase_;

    public ManualCpc ManualCpc
    {
        get
        {
            return campaignBiddingStrategyCase_ == CampaignBiddingStrategyOneofCase.ManualCpc ?
                (ManualCpc) campaignBiddingStrategy_ : null;
        }
        set
        {
            campaignBiddingStrategy_ = value;
            campaignBiddingStrategyCase_ = CampaignBiddingStrategyOneofCase.ManualCpc;
        }
    }

    public ManualCpm ManualCpm
    {
        get
        {
            return campaignBiddingStrategyCase_ == CampaignBiddingStrategyOneofCase.ManualCpm ?
                (ManualCpm) campaignBiddingStrategy_ : null;
        }
        set
        {
            campaignBiddingStrategy_ = value;
            campaignBiddingStrategyCase_ = CampaignBiddingStrategyOneofCase.ManualCpm;
        }
    }

    public CampaignBiddingStrategyOneofCase CampaignBiddingStrategyCase
    {
        get { return campaignBiddingStrategyCase_; }
    }
}

Étant donné que les propriétés OneOf partagent le stockage, une attribution peut écraser une précédente ce qui entraîne des bugs subtils. Par exemple,

Campaign campaign = new Campaign()
{
    ManualCpc = new ManualCpc()
    {
        EnhancedCpcEnabled = true
    },
    ManualCpm = new ManualCpm()
    {

    }
};

Dans ce cas, campaign.ManualCpc est désormais null depuis l'initialisation de Le champ campaign.ManualCpm remplace l'initialisation précédente pour campaign.ManualCpc

Conversion dans d'autres formats

Vous pouvez facilement convertir des objets protobuf au format JSON et inversement. C'est utiles lors de la création de systèmes qui doivent s'interfacer avec d'autres systèmes qui ont besoin de données dans des formats textuels tels que JSON ou XML.

GoogleAdsRow row = new GoogleAdsRow()
{
    Campaign = new Campaign()
    {
        Id = 123,
        Name = "Campaign 1",
        ResourceName = ResourceNames.Campaign(1234567890, 123)
    }
};
// Serialize to JSON and back.
string json = JsonFormatter.Default.Format(row);
row = GoogleAdsRow.Parser.ParseJson(json);

Vous pouvez également sérialiser un objet en octets et effectuer un retour arrière. La sérialisation binaire est plus en termes de mémoire et de stockage que le format JSON.

GoogleAdsRow row = new GoogleAdsRow()
{
    Campaign = new Campaign()
    {
        Id = 123,
        Name = "Campaign 1",
        ResourceName = ResourceNames.Campaign(1234567890, 123)
    }
};
// Serialize to bytes and back.
byte[] bytes = row.ToByteArray();
row = GoogleAdsRow.Parser.ParseFrom(bytes);