Google-Ads-GoogleAds-Client
view release on metacpan or search on metacpan
examples/advanced_operations/add_app_campaign.pl view on Meta::CPAN
printf "Created ad group with resource name: '%s'.\n",
$ad_group_resource_name;
return $ad_group_resource_name;
}
# Creates an App ad for a given ad group.
sub create_app_ad {
my ($api_client, $customer_id, $ad_group_resource_name) = @_;
# Create an ad group ad.
my $ad_group_ad = Google::Ads::GoogleAds::V24::Resources::AdGroupAd->new({
adGroup => $ad_group_resource_name,
status =>
Google::Ads::GoogleAds::V24::Enums::AdGroupAdStatusEnum::ENABLED,
ad => Google::Ads::GoogleAds::V24::Resources::Ad->new({
appAd => Google::Ads::GoogleAds::V24::Common::AppAdInfo->new({
headlines => [
create_ad_text_asset("A cool puzzle game"),
create_ad_text_asset("Remove connected blocks")
],
descriptions => [
create_ad_text_asset("3 difficulty levels"),
create_ad_text_asset("4 colorful fun skins")
],
# Optional: You can set up to 20 image assets for your campaign.
# images => [
# Google::Ads::GoogleAds::V24::Common::AdImageAsset->new({
# asset => "INSERT_IMAGE_ASSET_RESOURCE_NAME_HERE"
# })]
})})});
# Create an ad group ad operation.
my $ad_group_ad_operation =
Google::Ads::GoogleAds::V24::Services::AdGroupAdService::AdGroupAdOperation
->new({create => $ad_group_ad});
# Issue a mutate request to add the ad group ad.
my $ad_group_ads_response = $api_client->AdGroupAdService()->mutate({
customerId => $customer_id,
operations => [$ad_group_ad_operation]});
printf "Created ad group ad with resource name: '%s'.\n",
$ad_group_ads_response->{results}[0]{resourceName};
}
# Creates an ad text asset.
sub create_ad_text_asset {
my ($text) = @_;
return Google::Ads::GoogleAds::V24::Common::AdTextAsset->new({
text => $text
});
}
# Don't run the example if the file is being included.
if (abs_path($0) ne abs_path(__FILE__)) {
return 1;
}
# Get Google Ads Client, credentials will be read from ~/googleads.properties.
my $api_client = Google::Ads::GoogleAds::Client->new();
# By default examples are set to die on any server returned fault.
$api_client->set_die_on_faults(1);
# Parameters passed on the command line will override any parameters set in code.
GetOptions("customer_id=s" => \$customer_id);
# Print the help message if the parameters are not initialized in the code nor
# in the command line.
pod2usage(2) if not check_params($customer_id);
# Call the example.
add_app_campaign($api_client, $customer_id =~ s/-//gr);
=pod
=head1 NAME
add_app_campaign
=head1 DESCRIPTION
This example adds an App campaign.
For guidance regarding App campaigns, see:
https://developers.google.com/google-ads/api/docs/app-campaigns/overview
To get campaigns, run basic_operations/get_campaigns.pl.
To upload image assets for this campaign, run misc/upload_image_asset.pl.
=head1 SYNOPSIS
add_app_campaign.pl [options]
-help Show the help message.
-customer_id The Google Ads customer ID.
=cut
( run in 0.558 second using v1.01-cache-2.11-cpan-f56aa216473 )