v18 (2024-10-16)
The following new features and updates were added in v18.
Account Management
- (For allowlisted accounts only) Added
DataLinkService.CreateDataLink, which allows linking a Google Ads account to creator videos hosted on the creator's YouTube channel. Video linking enables the Google Ads account to run partnership ads using creator videos.
Ad Groups
- Added
AdGroup.exclude_demographic_expansionwhich lets you exclude demographics from being expanded whenoptimized_targeting_enabledistrue, a feature that was previously only supported for Demand Gen.
Ads
- Added
AdGroupAd.ad_group_ad_asset_automation_settings, which allows opting ads into or out of automatic asset generation. - Added the following values to
AssetAutomationType:GENERATE_VERTICAL_YOUTUBE_VIDEOSGENERATE_SHORTER_YOUTUBE_VIDEOS
- Added
AdNetworkType.GOOGLE_OWNED_CHANNELS, which is used by ads that serve on Google-owned channels such as YouTube, Gmail, and the Discover feed.
Assets
- Renamed
AssetType.DISCOVERY_CAROUSEL_CARDtoAssetType.DEMAND_GEN_CAROUSEL_CARD.
Campaigns
- Added
metrics.store_visits_last_click_model_attributed_conversions, which returns the number of store visits attributed by the last click model of a campaign. - Added the following video view-related metrics for a campaign:
- Added
metrics.results_conversions_purchase, which returns conversion purchases for the unified goals results of a campaign. - Changed the default value of
DemandGenCampaignSettings.upgraded_targetingfromfalsetotrue.
Criterion
- Added
content_criterion_viewwhich returns performance metrics of targeted contents, such as keywords, placements and topics, for Display, Demand Gen and Video campaigns.
Hotel & Travel
- Support for Travel Feeds in Search Ads
- Added
ClickType.TRAVEL_ASSETSto allow segmentation of metrics of Travel Feeds in Search Ads. - Added
AssetSetType.TRAVEL_FEEDwhich can be used to opt-in and opt-out of using Travel Feed in Search Ads.
- Added
- (For allowlisted accounts only) Added travel itinerary as a new conversion value rule with the following new fields and values:
ConversionValueRule.itinerary_conditionwithValueRuleItineraryCondition, which allows for specifying an advance booking window, an itinerary length, and a travel start days of weekConversionValueRulePrimaryDimensionEnum.ITINERARYValueRuleSetDimension.ITINERARY
- Added the following segments for
campaignandad_groupreports to allow for segmenting performance data based on specific destinations (cities, countries and regions) for Hotel and Search campaigns:
Local Services
PhoneCallDetails.call_recording_urlwill be empty, instead of providing an invalid URL if the call recording doesn't exist for the given Local Services lead conversation.- Added
CategoryBid.target_cpa_bid_microwhich allows for setting target CPA for a category throughCampaign.local_services_campaign_settings.
Performance Max
- Support for brand guidelines
- Added
Campaign.brand_guidelines_enabledwhich shows whether brand guidelines are enabled for a given Performance Max campaign. If enabled, assets withfield_typeset toBUSINESS_NAME,LOGO,LANDSCAPE_LOGOmust be linked asCampaignAssetresources instead ofAssetGroupAssetresources. - Added
CampaignError.REQUIRED_BUSINESS_NAME_ASSET_NOT_LINKEDandCampaignError.REQUIRED_LOGO_ASSET_NOT_LINKEDerrors, which indicate that Performance Max campaigns with brand guidelines enabled don't have the requiredCampaignAssetresources linked to the campaign. - When brand guidelines are enabled, at least one asset with
field_typeset toBUSINESS_NAMEand at least one withLOGOmust be linked to the campaign asCampaignAssetresources. Performance Max campaigns for online sales with a product feed must meet this requirement only when there are assets that are linked to the campaign's asset groups. - Added the following values to
AssetLinkError:BRAND_ASSETS_NOT_LINKED_AT_ASSET_GROUP_LEVEL, which is thrown when attempting to link brand assets to campaigns asCampaignAssetresources instead ofAssetGroupAssetresources in Performance Max campaigns with brand guidelines not enabled.BRAND_ASSETS_NOT_LINKED_AT_CAMPAIGN_LEVELerror, which is thrown when attempting to link brand assets to campaigns asAssetGroupAssetresources instead ofCampaignAssetresources in Performance Max campaigns with brand guidelines enabled.
- Added
- Added
performance_max_placement_viewwhich returns impressions of the placements where Performance Max ads served. - Added
AssetGroupListingGroupFilterError.TREE_WAS_INVALID_BEFORE_MUTATION
Planning
- (For allowlisted accounts only) Added a new service with the method
ContentCreatorInsightsService.GenerateCreatorInsights, which allows users to explore insights about top YouTube Creators. This allows customers to search for creators given an audience targeting and content targeting combination or creator insights given a list of YouTube Channel IDs. - Updates to
AudienceInsightsService.GenerateSuggestedTargetingInsights:- Moved
audience,baseline_audienceanddata_monthintoaudience_definition. - Added
audience_descriptionto generate targeting suggestions from a free form text description using Gen AI.
- Moved
- Added
AudienceInsightsService.GenerateTargetingSuggestionMetricswhich returns potential reach metrics for given audience targeting combinations.
Recommendations
RecommendationService.GenerateRecommendationscan now be used to generate recommendations about optimized budget suggestions during campaign construction, by including theCAMPAIGN_BUDGETrecommendation type inGenerateRecommendationsRequest.recommendation_types[]. This works for Performance Max and Search campaigns.
Reporting
- Replaced the
summary_row_settingandreturn_total_results_countfields ofSearchGoogleAdsRequestwith thesearch_settingsfield, whose type isSearchSettingswith the following fields:omit_resultsreturn_summary_rowreturn_total_results_count
- Added the following new metrics about general invalid clicks, such as those generated by bots or crawlers, those having irregular patterns. They can be queried with the
campaignreport. - Added the following values to
QuotaError:EXCESSIVE_SHORT_TERM_QUERY_RESOURCE_CONSUMPTIONEXCESSIVE_LONG_TERM_QUERY_RESOURCE_CONSUMPTION
v17.1.0 (2024-08-07)
The following new features and updates were added in v17_1.
Assets
AdGroupAdService.RemoveAutomaticallyCreatedAssets()lets you remove specified automatically created assets linked to Responsive Search Ads.
Audiences
- New enum values in
UserListCustomerTypeCategory:LOYALTY_TIER_1_MEMBERSLOYALTY_TIER_2_MEMBERSLOYALTY_TIER_3_MEMBERSLOYALTY_TIER_4_MEMBERSLOYALTY_TIER_5_MEMBERSLOYALTY_TIER_6_MEMBERSLOYALTY_TIER_7_MEMBERS
Campaigns
ShareablePreviewService.GenerateShareablePreviews()generates the URLs (shareable_preview_urlin the response) for shareable ad previews for enabled and paused asset groups.- The
expiration_date_timefield indicates the expiration date of the URLs in the response. - If an error occurs, the method will return
partial_failure_errorinstead of the URLs.
- The
Change History
- New change status resource type:
ASSET_GROUP.
Conversions
- New segment field for SKAdNetwork version:
segments.sk_ad_network_version offline_conversion_upload_conversion_action_summarywhich exposes conversion upload diagnostics at the conversion action level.- The following metrics are added to the offline diagnostics reports to convey the number of uploaded conversions that are still being processed:
Planning
AudienceInsights.GenerateAudienceOverlapInsights()which accepts an input primary attribute and a collection of audience attributes, and returns the estimates of the overlap of potential YouTube reach between the primary attribute and the audience attributes.
Reporting
- Support for segmenting
per_store_viewbased onsegments.date
Videos
- Support for retrieving information related to the following standard bidding strategies for video campaigns using reports, such as,
ad_group,campaign:Campaign.fixed_cpm(Fixed CPM (cost per thousand impression))Campaign.target_cpv(Target CPV (cost per view))
Campaign.video_campaign_settingswhich lets you determine on which inventories the video ads can be shown, using the following report fields:segments.ad_format_typewhich lets you segment the following reports based on the video ad format type:
v17 (2024-06-05)
The following features and changes were added in v17.
Ads
- Removed
AdService.getAd. This brings theAdServicein line with other services in the Google Ads API. See Retrieving objects for the recommended way to fetch ads and other resource types. - Added more validations for
ImageAdInfo.image_assetregarding dimensions and format. The following errors may be thrown if the image is invalid:
Assets
- Added new enum:
ClickType.AD_IMAGE - Added the following new reports with new metrics for Performance Max and Search campaigns:
Audiences
Batch Jobs
- Added
BatchJobError.REQUEST_TOO_LARGE, which will be thrown when the submittedAddBatchJobOperationsRequestis larger than 10484504 bytes. - Added support for setting
MutateOperation.asset_group_operationwhen usingBatchJobService. This lets you use batch processing to create and manage entire Performance Max campaigns. See our new dedicated guide.
Campaigns
- Renamed Discovery to Demand Gen in all fields, enums, errors of all
resources across the Google Ads API, such as campaigns, ads, and assets. For
example,
AdvertisingChannelType.DISCOVERYis nowAdvertisingChannelType.DEMAND_GEN. - Added
Campaign.keyword_match_typeto let you set keyword match type for all keywords in a campaign.
Conversions
- For SKAdNetwork
conversions,
- Renamed
segments.sk_ad_network_conversion_valuetosegments.sk_ad_network_fine_conversion_value. - Added
segments.sk_ad_network_redistributed_fine_conversion_value.
- Renamed
- The following metrics are now returned with the response even when they are zero. This makes them consistent with other metrics.
Criteria
- Added to following fields to
AdGroupCriterionto show whether the ad group criterion is serving or the reasons why it's not serving:primary_statusprimary_status_reasons
- Added support for
metrics.search_impression_shareforgender_view - Added support for
metrics.phone_callsforkeyword_view
Local Services
- Added
LocalServicesLeadService.AppendLeadConversation()used to append a newLocalServicesLeadConversationtoLocalServicesLead, which sends the messages to users through appropriate channels like SMS depending on how the lead was created.- The size of
AppendLeadConversationRequest.conversationsis limited to 1,000. - Only
LocalServicesLeadwithlead_typeset toLeadType.MESSAGEcan be specified inConversation.local_services_lead.
- The size of
- Added new enum values to
ConversationType:WHATSAPPto represent a conversation introduced through WhatsApp.ADS_APIto represent a conversation introduced using the newLocalServicesLeadService.AppendLeadConversation()method.
- Added the following new fields to
local_services_verification_artifact:local_services_verification_artifact.insurance_verification_artifact.expiration_date_timelocal_services_verification_artifact.license_verification_artifact.expiration_date_time
Reporting
- You can now select only fields related to one linked product
when querying
product_link. Selecting multiple fields of several linked products will throwQueryError.PROHIBITED_FIELD_COMBINATION_IN_SELECT_CLAUSE. For example,product_link.advertising_partner.customerandproduct_link.data_partner.data_partner_idcannot be selected in the same query. - Passing a
page_sizetoGoogleAdsService.Searchwill result in aRequestError.PAGE_SIZE_NOT_SUPPORTEDerror.
Shopping
- Added a new report
shopping_product, which corresponds to the Products page of the Google Ads UI. It supports returning data related to the current state of products from Google Merchant Center accounts linked to a Google Ads account.- You can filter metrics from the
shopping_productreport usingsegments.datewhen usingGoogleAdsService.SearchorGoogleAdsService.SearchStream. Segmentation by date is not permitted and will return aShoppingProductError.UNSUPPORTED_DATE_SEGMENTATIONerror.
- You can filter metrics from the
Unified Goals
- Added
UserListCustomerTypeService.MutateUserListCustomerTypes()to configure audience customer types. - Removed
CustomerLifecycleGoal.lifecycle_goal_customer_definition_settings. To configure audience settings of customer lifecycle goals, useUserListCustomerTypeService.MutateUserListCustomerTypes()instead.- Attach or unattach a user list by setting
UserListCustomerType.customer_type_categorytoUserListCustomerTypeCategory.PURCHASERSto include it into or exclude it from an existing customer definition for customer lifecycle goals, respectively. Visit segment your audiences for more details.
- Attach or unattach a user list by setting
Videos
- Added the following values to
ContentLabelType. You can exclude theseContentLabelTypesat the customer level:BRAND_SUITABILITY_CONTENT_FOR_FAMILIESBRAND_SUITABILITY_GAMES_FIGHTINGBRAND_SUITABILITY_GAMES_MATUREBRAND_SUITABILITY_HEALTH_SENSITIVEBRAND_SUITABILITY_HEALTH_SOURCE_UNDETERMINEDBRAND_SUITABILITY_NEWS_RECENTBRAND_SUITABILITY_NEWS_SENSITIVEBRAND_SUITABILITY_NEWS_SOURCE_NOT_FEATUREDBRAND_SUITABILITY_POLITICSBRAND_SUITABILITY_RELIGION
- Added
AdVideoAsset.ad_video_asset_infoto support inventory preferences for video assets when creatingDemandGenVideoResponsiveAdInfo. - (Allowlisted accounts only) Made
Campaign.video_brand_safety_suitabilitymutable.
v16.1.0 (2024-04-24)
The following features and changes were added in v16.1.
Account Management
CustomerNegativeCriterion.ip_blockwhich supports adding an IP as a negative criterion at the customer level.- New enum value:
ProductLinkError.LINK_EXISTS. - New enum value:
ProductLinkInvitationError.CUSTOMER_NOT_PERMITTED_TO_CREATE_INVITATION.
Assets
- Support for assets related to Demand Gen to
ad_group_ad_asset_viewandasset_field_type_view. - New enum value:
AssetFieldType.DISCOVERY_CAROUSEL_CARD.
Audiences
- New enum value:
ResourceLimitType.LOOKALIKE_USER_LISTS_PER_CUSTOMERwhich limits the number of lookalike user lists a customer can have to 1000.
Campaigns
- Support for returning Target
ROAS campaign bid simulations for
App campaigns using the
campaign_simulationreport. - New enum value:
CampaignError.DYNAMIC_TEXT_ASSET_CANNOT_OPT_OUT_WITH_FINAL_URL_EXPANSION_OPT_IN. - New enum value:
AdGroupPrimaryStatusReason.AD_GROUP_PAUSED_DUE_TO_LOW_ACTIVITY. - New enum value:
CampaignCriterionError.CANNOT_REMOVE_ALL_LOCATIONS_DUE_TO_TOO_MANY_COUNTRY_EXCLUSIONS.
Conversions
SkAdNetworkConversionValueSchema.postback_mappingswhich supports SKAdNetwork 4.0 features.- Added support for warnings for
CustomerSkAdNetworkConversionValueSchemaServiceasMutateCustomerSkAdNetworkConversionValueSchemaRequest.enable_warnings. When set totrue, any non-blocking errors pertaining to operation failures will be returned asMutateCustomerSkAdNetworkConversionValueSchemaResponse.warning. - New enum values in
CustomerSkAdNetworkConversionValueSchemaError:INVALID_EVENT_COUNTERINVALID_EVENT_NAME
Criteria
- New fields in
BrandInfo:display_nameprimary_urlrejection_reasonstatus
- New enum:
BrandRequestRejectionReason. - New enum value:
CriterionType.LIFE_EVENT.
Experiments
- New enum value:
ExperimentError.INVALID_DURATION_FOR_AN_EXPERIMENT.
Local Services
local_services_lead.credit_details.credit_stateandlocal_services_lead.credit_details.credit_state_last_update_date_timewhich returns the state of credit and the timestamp when the credit state was updated, respectively.local_services_lead_conversation.message_details.attachment_urlswhich returns the URLs that can be used to download the contents of the attachment.
Videos
customer.video_brand_safety_suitabilityandBrandSafetySuitabilitywhich support retrieving video brand safety suitability at the customer level.- New enum value:
VideoCampaignError.MUTATE_REQUIRES_RESERVATION.
v16 (2024-02-21)
The following features and changes were added in v16.
Account Management
- Migrated
advertising_partnerfromAccountLinktoProductLinkandProductLinkInvitation. - Removed
data_partnerandgoogle_adsfromAccountLink. - Added
IdentityVerificationServiceto manage advertiser verification.StartIdentityVerification()is used to start a verification session using the providedverification_program. It creates a new verification session and returns an empty response for a successfully created verification.GetIdentityVerification()can be used for retrieving verification information, which returns several objects ofIdentityVerification. EachIdentityVerificationincludes:verification_programwhich is the identity verification program typeidentity_verification_requirementthat contains details related to the deadline by which the advertiser should finish verificationverification_progressthat contains details related to the verification session including:program_statusrepresents the current status of this verification sessionaction_urldirects the customer to a URL to complete the verification.invitation_link_expiration_timerepresents the expiration date for theaction_url
- Enums:
- Errors:
- Added
AuthorizationError.ACTION_NOT_PERMITTED_FOR_SUSPENDED_ACCOUNT.
Assets
- Changes to
asset_group:- Added support for time-related segments, such as
segments.yearandsegments.month. - Made
campaignan attributed resource instead of segmenting resource.
- Added support for time-related segments, such as
Campaigns
- Changes to Demand Gen campaigns:
- Added support for setting
Campaign.shopping_settingto an existing Demand Gen campaign. - Added
ShoppingSetting.disable_product_feedto disable the optional product feed of Demand Gen campaigns. - Added
Ad.demand_gen_product_adand the correspondingDemandGenProductAdInfo, available to Demand Gen campaigns with a non-nullCampaign.shopping_setting.
- Added support for setting
- Added to following fields to
AdGroupto show whether the ad group is serving or the reasons why it's not serving:primary_statusprimary_status_reasons
- Added to following fields to
AdGroupAdto show whether the ad group ad is serving or the reasons why it's not serving:primary_statusprimary_status_reasons
- Added the following values to
AdGroupError:CANNOT_ADD_AD_GROUP_FOR_CAMPAIGN_TYPEINVALID_STATUS
Experiment
- Added
Experiment.sync_enabledto specify if sync should be enabled in the experiment. With sync enabled, changes made to the original campaign while your experiment is running, are automatically copied to the experiment campaign. - Added
ExperimentError.CANNOT_ENABLE_SYNC_FOR_UNSUPPORTED_EXPERIMENT_TYPE. - Added
CampaignError.CANNOT_MODIFY_TEXT_ASSET_AUTOMATION_WITH_ENABLED_TRIAL.
Hotel & Travel
- Added the following fields to
ListingDimensionInfofor a Things to do ad to enable creating listing groups based on the state and city where the travel activity is available: - Added support for the following segments to
travel_activity_performance_view:
Local Services
- Added
LocalServicesVerificationArtifact.business_registration_check_verification_artifactandBusinessRegistrationCheckArtifactto allow advertisers to monitor the progress of the business registration verification process. - Added a new resource
local_services_employeeto allow advertisers to retrieve the employee information they've added.
Planning
- Removed
scorefromAudienceInsightsAttributeMetadata.
Recommendations
- Added
RecommendationService.GenerateRecommendations()which returns recommendations based on the specified settings, such as recommendation types and advertising channel types. This is particularly helpful during campaign construction. - Added
RecommendationMetrics.conversions_value. - Recommended keywords with unset keyword match type now have
recommended_match_typeset toUNSPECIFIEDinstead ofUNKNOWN. - Added the following types of recommendations:
MAXIMIZE_CONVERSION_VALUE_OPT_INwhich recommends opting in to the Maximize conversion value bidding strategyIMPROVE_GOOGLE_TAG_COVERAGEwhich recommends deploying Google Tag on more pagesPERFORMANCE_MAX_FINAL_URL_OPT_INwhich recommends turning on final URL expansion for your Performance Max campaignsREFRESH_CUSTOMER_MATCH_LISTwhich recommends updating a customer list that hasn't been updated in the last 90 daysCUSTOM_AUDIENCE_OPT_INwhich recommends creating a custom audienceLEAD_FORM_ASSETwhich recommends adding lead form assets at the campaign or customer levelIMPROVE_DEMAND_GEN_AD_STRENGTHwhich recommends improving ad strength on Demand Gen campaigns
Shopping
- Added
CampaignError.CANNOT_LINK_TO_COMPARISON_SHOPPING_SERVICE_ACCOUNTandCampaignError.CANNOT_TARGET_NETWORK_FOR_COMPARISON_SHOPPING_SERVICE_LINKED_ACCOUNTSin order to provide more detailed errors for Shopping campaigns linked to a Comparison Shopping Service Center account. - Added the following values to
AssetGroupListingGroupFilterError:DIMENSION_TYPE_NOT_ALLOWEDDUPLICATE_WEBPAGE_FILTER_UNDER_ASSET_GROUPFILTER_EXCLUSION_NOT_ALLOWEDLISTING_SOURCE_NOT_ALLOWEDMULTIPLE_LISTING_SOURCESMULTIPLE_WEBPAGE_CONDITION_TYPES_NOT_ALLOWEDMULTIPLE_WEBPAGE_TYPES_PER_ASSET_GROUPPAGE_FEED_FILTER_HAS_PARENT
Lifecycle Goals
- Added
updatetoCustomerLifecycleGoalOperationandCampaignLifecycleGoalOperationto make these operation types consistent with other operation types in the API.
Archived release notes
See Sunsetted versions for archived release notes.