Nell'API Google Ads, gli aggiornamenti vengono eseguiti utilizzando una maschera di campo. La maschera dei campi elenca tutti i campi che intendi modificare con l'aggiornamento e tutti i campi specificati che non sono presenti nella maschera dei campi vengono ignorati, anche se inviati al server.
Utilità FieldMasks
Il modo consigliato per generare maschere di campo è utilizzare la nostra utility di maschere di campo integrata (FieldMasks
), che consente di generare maschere di campo da un oggetto modificato anziché crearle da zero.
Ecco un esempio di aggiornamento di una campagna:
my $campaign = Google::Ads::GoogleAds::V19::Resources::Campaign->new({
resourceName =>
Google::Ads::GoogleAds::V19::Utils::ResourceNames::campaign(
$customer_id, $campaign_id
),
status => PAUSED,
networkSettings =>
Google::Ads::GoogleAds::V19::Resources::NetworkSettings->new({
targetSearchNetwork => "false"
})
});
my $campaign_operation =
Google::Ads::GoogleAds::V19::Services::CampaignService::CampaignOperation->new({
update => $campaign,
updateMask => all_set_fields_of($campaign)
});
Questo esempio crea innanzitutto un oggetto Campaign
impostando il nome della risorsa
utilizzando l'utilità ResourceNames
, in modo che l'API sappia
quale campagna viene aggiornata.
L'esempio utilizza il metodo
FieldMasks::all_set_fields_of()
nella campagna per produrre automaticamente una maschera di campi che enumera tutti
i campi impostati. Puoi quindi passare la maschera restituita direttamente alla chiamata di aggiornamento.
FieldMasks::all_set_fields_of()
è un metodo di comodità per
FieldMasks::field_mask()
.
Confronta l'oggetto passato con un oggetto vuoto della stessa classe. Quindi, nel codice riportato sopra, puoi anche utilizzare
field_mask(Google::Ads::GoogleAds::V19::Resources::Campaign->new({}), $campaign)
anziché all_set_fields_of($campaign)
.
Creazione manuale di una maschera
Per creare una maschera di campo da zero, devi prima creare un oggetto
Google::Ads::GoogleAds::Common::FieldMask
, poi creare un riferimento ad array compilato con i nomi di tutti i campi
che intendi modificare e infine assegnare il riferimento ad array al campo
paths
della maschera di campo.
my $field_mask = Google::Ads::GoogleAds::Common::FieldMask->new({
paths => ["status", "name"]
});
Aggiornamento dei campi degli oggetti e dei relativi sottocampi
I campi degli oggetti possono avere sottocampi (ad esempio MaximizeConversions
che ne ha tre: target_cpa_micros
, cpc_bid_ceiling_micros
e cpc_bid_floor_micros
) oppure non averne nessuno (ad esempio ManualCpm
).
Campi oggetto senza sottocampi definiti
Un campo dell'oggetto in Perl è equivalente a un MESSAGE
protobuf nelle librerie client in esecuzione su gRPC. Quando aggiorni un campo dell'oggetto non definito con sottocampi, utilizza l'utilità FieldMasks per generare una maschera dei campi, come descritto sopra.
Campi oggetto con sottocampi definiti
Quando aggiorni un campo dell'oggetto definito con sottocampi senza impostare esplicitamente uno dei sottocampi nel messaggio, devi aggiungere manualmente ciascuno dei sottocampi dell'oggetto mutabile a FieldMask
, in modo simile all'esempio riportato sopra che crea una maschera di campo da zero.
Un esempio comune è l'aggiornamento della strategia di offerta di una campagna senza impostare alcun campo della nuova strategia di offerta. L'esempio seguente mostra come aggiornare una campagna in modo che utilizzi la strategia di offerta MaximizeConversions
senza impostare nessuno dei campi secondari della strategia di offerta.
In questo caso, l'utilizzo dei metodi all_set_fields_of()
e field_mask()
dell'utilità
FieldMasks non raggiunge l'obiettivo previsto.
L'esempio seguente genera una maschera di campo che include
maximize_conversions
. Tuttavia, l'API Google Ads non consente questo comportamento per evitare di cancellare accidentalmente i campi e genera un errore FieldMaskError.FIELD_HAS_SUBFIELDS
.
# Creates a campaign with the proper resource name and an empty
# MaximizeConversions field.
my $campaign = Google::Ads::GoogleAds::V19::Resources::Campaign->new({
resourceName =>
Google::Ads::GoogleAds::V19::Utils::ResourceNames::campaign(
$customer_id, $campaign_id
),
maximizeConversions =>
Google::Ads::GoogleAds::V19::Resources::MaximizeConversions->new()
});
# Constructs an operation, using the FieldMasks' all_set_fields_of utility to
# derive the update mask. The field mask will include 'maximize_conversions',
# which will produce a FieldMaskError.FIELD_HAS_SUBFIELDS error.
my $campaign_operation =
Google::Ads::GoogleAds::V19::Services::CampaignService::CampaignOperation->new({
update => $campaign,
updateMask => all_set_fields_of($campaign)
});
# Sends the operation in a mutate request that will result in a
# FieldMaskError.FIELD_HAS_SUBFIELDS error because empty object fields cannot
# be included in a field mask.
my $response = $api_client->CampaignService()->mutate({
customerId => $customer_id,
operations => [$campaign_operation]
});
L'esempio seguente mostra come aggiornare correttamente una campagna per utilizzare la strategia di offerta
MaximizeConversions
senza impostare nessuno dei relativi campi secondari.
# Creates a campaign with the proper resource name.
my $campaign = Google::Ads::GoogleAds::V19::Resources::Campaign->new({
resourceName => Google::Ads::GoogleAds::V19::Utils::ResourceNames::campaign(
$customer_id, $campaign_id
)
});
# Creates a field mask from the existing campaign and adds all of the fields
# on the MaximizeConversions bidding strategy to the field mask. Because these
# fields are included in the field mask but excluded from the campaign object,
# the Google Ads API will set the campaign's bidding strategy to a
# MaximizeConversions object with none of its subfields set.
# Only include 'maximize_conversions.target_cpa_micros' in the field mask
# as it is the only mutable subfield on MaximizeConversions when used as a
# standard bidding strategy.
#
# Learn more about standard and portfolio bidding strategies here:
# https://developers.google.com/google-ads/api/docs/campaigns/bidding/assign-strategies
my $field_mask = all_set_fields_of($campaign);
push @{$field_mask->{paths}}, "maximize_conversions.target_cpa_micros";
# Creates an operation to update the campaign with the specified fields.
my $campaign_operation =
Google::Ads::GoogleAds::V19::Services::CampaignService::CampaignOperation->new({
update => $campaign,
updateMask => $field_mask
});
Cancellazione dei campi
I campi possono essere cancellati esplicitamente aggiungendoli alla maschera di campo come mostrato sopra o impostando il campo su un valore vuoto o non definito. Ad esempio, assumere di avere una campagna che utilizza una strategia di offerta MaximizeConversions
e che il campo target_cpa_micros
sia impostato su un valore superiore a 0
.
# Creates a campaign with the proper resource name and a MaximizeConversions
# object with target_cpa_micros set to 0.
my $campaign =
Google::Ads::GoogleAds::V19::Resources::Campaign->new({
resourceName => Google::Ads::GoogleAds::V19::Utils::ResourceNames::campaign(
$customer_id, $campaign_id
),
maximizeConversions => Google::Ads::GoogleAds::V19::Resources::MaximizeConversions->new({
targetCpaMicros => 0
})
});
# Constructs an operation, using the FieldMasks' all_set_fields_of utility to
# derive the update mask, which will include 'maximize_conversions.target_cpa_micros'.
my $campaign_operation =
Google::Ads::GoogleAds::V19::Services::CampaignService::CampaignOperation->new({
update => $campaign,
updateMask => all_set_fields_of($campaign)
});
Tieni presente che i campi con sottocampi nidificati possono essere cancellati solo cancellando ciascuno dei singoli sottocampi, come mostrato in Campi oggetto con sottocampi definiti.