/resources/ad_group_criterion.proto,/resources/ad_group_criterion.proto

--- v16/resources/ad_group_criterion.proto  2024-04-24 19:38:30.000000000 +0000
+++ v17/resources/ad_group_criterion.proto  2024-05-29 15:59:04.000000000 +0000
@@ -1,355 +1,368 @@
-// Copyright 2023 Google LLC
+// Copyright 2024 Google LLC
 //
 // Licensed under the Apache License, Version 2.0 (the "License");
 // you may not use this file except in compliance with the License.
 // You may obtain a copy of the License at
 //
 //     http://www.apache.org/licenses/LICENSE-2.0
 //
 // Unless required by applicable law or agreed to in writing, software
 // distributed under the License is distributed on an "AS IS" BASIS,
 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 // See the License for the specific language governing permissions and
 // limitations under the License.

 syntax = "proto3";

-package google.ads.googleads.v16.resources;
+package google.ads.googleads.v17.resources;

-import "google/ads/googleads/v16/common/criteria.proto";
-import "google/ads/googleads/v16/common/custom_parameter.proto";
-import "google/ads/googleads/v16/enums/ad_group_criterion_approval_status.proto";
-import "google/ads/googleads/v16/enums/ad_group_criterion_status.proto";
-import "google/ads/googleads/v16/enums/bidding_source.proto";
-import "google/ads/googleads/v16/enums/criterion_system_serving_status.proto";
-import "google/ads/googleads/v16/enums/criterion_type.proto";
-import "google/ads/googleads/v16/enums/quality_score_bucket.proto";
+import "google/ads/googleads/v17/common/criteria.proto";
+import "google/ads/googleads/v17/common/custom_parameter.proto";
+import "google/ads/googleads/v17/enums/ad_group_criterion_approval_status.proto";
+import "google/ads/googleads/v17/enums/ad_group_criterion_primary_status.proto";
+import "google/ads/googleads/v17/enums/ad_group_criterion_primary_status_reason.proto";
+import "google/ads/googleads/v17/enums/ad_group_criterion_status.proto";
+import "google/ads/googleads/v17/enums/bidding_source.proto";
+import "google/ads/googleads/v17/enums/criterion_system_serving_status.proto";
+import "google/ads/googleads/v17/enums/criterion_type.proto";
+import "google/ads/googleads/v17/enums/quality_score_bucket.proto";
 import "google/api/field_behavior.proto";
 import "google/api/resource.proto";

-option csharp_namespace = "Google.Ads.GoogleAds.V16.Resources";
-option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v16/resources;resources";
+option csharp_namespace = "Google.Ads.GoogleAds.V17.Resources";
+option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v17/resources;resources";
 option java_multiple_files = true;
 option java_outer_classname = "AdGroupCriterionProto";
-option java_package = "com.google.ads.googleads.v16.resources";
+option java_package = "com.google.ads.googleads.v17.resources";
 option objc_class_prefix = "GAA";
-option php_namespace = "Google\\Ads\\GoogleAds\\V16\\Resources";
-option ruby_package = "Google::Ads::GoogleAds::V16::Resources";
+option php_namespace = "Google\\Ads\\GoogleAds\\V17\\Resources";
+option ruby_package = "Google::Ads::GoogleAds::V17::Resources";

 // Proto file describing the ad group criterion resource.

 // An ad group criterion.
 // The ad_group_criterion report only returns criteria that were explicitly
 // added to the ad group.
 message AdGroupCriterion {
   option (google.api.resource) = {
     type: "googleads.googleapis.com/AdGroupCriterion"
     pattern: "customers/{customer_id}/adGroupCriteria/{ad_group_id}~{criterion_id}"
   };

   // A container for ad group criterion quality information.
   message QualityInfo {
     // Output only. The quality score.
     //
     // This field may not be populated if Google does not have enough
     // information to determine a value.
     optional int32 quality_score = 5
         [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. The performance of the ad compared to other advertisers.
-    google.ads.googleads.v16.enums.QualityScoreBucketEnum.QualityScoreBucket
+    google.ads.googleads.v17.enums.QualityScoreBucketEnum.QualityScoreBucket
         creative_quality_score = 2 [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. The quality score of the landing page.
-    google.ads.googleads.v16.enums.QualityScoreBucketEnum.QualityScoreBucket
+    google.ads.googleads.v17.enums.QualityScoreBucketEnum.QualityScoreBucket
         post_click_quality_score = 3
         [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. The click-through rate compared to that of other
     // advertisers.
-    google.ads.googleads.v16.enums.QualityScoreBucketEnum.QualityScoreBucket
+    google.ads.googleads.v17.enums.QualityScoreBucketEnum.QualityScoreBucket
         search_predicted_ctr = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
   }

   // Estimates for criterion bids at various positions.
   message PositionEstimates {
     // Output only. The estimate of the CPC bid required for ad to be shown on
     // first page of search results.
     optional int64 first_page_cpc_micros = 6
         [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. The estimate of the CPC bid required for ad to be displayed
     // in first position, at the top of the first page of search results.
     optional int64 first_position_cpc_micros = 7
         [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. The estimate of the CPC bid required for ad to be displayed
     // at the top of the first page of search results.
     optional int64 top_of_page_cpc_micros = 8
         [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. Estimate of how many clicks per week you might get by
     // changing your keyword bid to the value in first_position_cpc_micros.
     optional int64 estimated_add_clicks_at_first_position_cpc = 9
         [(google.api.field_behavior) = OUTPUT_ONLY];

     // Output only. Estimate of how your cost per week might change when
     // changing your keyword bid to the value in first_position_cpc_micros.
     optional int64 estimated_add_cost_at_first_position_cpc = 10
         [(google.api.field_behavior) = OUTPUT_ONLY];
   }

   // Immutable. The resource name of the ad group criterion.
   // Ad group criterion resource names have the form:
   //
   // `customers/{customer_id}/adGroupCriteria/{ad_group_id}~{criterion_id}`
   string resource_name = 1 [
     (google.api.field_behavior) = IMMUTABLE,
     (google.api.resource_reference) = {
       type: "googleads.googleapis.com/AdGroupCriterion"
     }
   ];

   // Output only. The ID of the criterion.
   //
   // This field is ignored for mutates.
   optional int64 criterion_id = 56 [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. The display name of the criterion.
   //
   // This field is ignored for mutates.
   string display_name = 77 [(google.api.field_behavior) = OUTPUT_ONLY];

   // The status of the criterion.
   //
   // This is the status of the ad group criterion entity, set by the client.
   // Note: UI reports may incorporate additional information that affects
   // whether a criterion is eligible to run. In some cases a criterion that's
   // REMOVED in the API can still show as enabled in the UI.
   // For example, campaigns by default show to users of all age ranges unless
   // excluded. The UI will show each age range as "enabled", since they're
   // eligible to see the ads; but AdGroupCriterion.status will show "removed",
   // since no positive criterion was added.
-  google.ads.googleads.v16.enums.AdGroupCriterionStatusEnum
+  google.ads.googleads.v17.enums.AdGroupCriterionStatusEnum
       .AdGroupCriterionStatus status = 3;

   // Output only. Information regarding the quality of the criterion.
   QualityInfo quality_info = 4 [(google.api.field_behavior) = OUTPUT_ONLY];

   // Immutable. The ad group to which the criterion belongs.
   optional string ad_group = 57 [
     (google.api.field_behavior) = IMMUTABLE,
     (google.api.resource_reference) = {
       type: "googleads.googleapis.com/AdGroup"
     }
   ];

   // Output only. The type of the criterion.
-  google.ads.googleads.v16.enums.CriterionTypeEnum.CriterionType type = 25
+  google.ads.googleads.v17.enums.CriterionTypeEnum.CriterionType type = 25
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Immutable. Whether to target (`false`) or exclude (`true`) the criterion.
   //
   // This field is immutable. To switch a criterion from positive to negative,
   // remove then re-add it.
   optional bool negative = 58 [(google.api.field_behavior) = IMMUTABLE];

   // Output only. Serving status of the criterion.
-  google.ads.googleads.v16.enums.CriterionSystemServingStatusEnum
+  google.ads.googleads.v17.enums.CriterionSystemServingStatusEnum
       .CriterionSystemServingStatus system_serving_status = 52
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Approval status of the criterion.
-  google.ads.googleads.v16.enums.AdGroupCriterionApprovalStatusEnum
+  google.ads.googleads.v17.enums.AdGroupCriterionApprovalStatusEnum
       .AdGroupCriterionApprovalStatus approval_status = 53
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. List of disapproval reasons of the criterion.
   //
   // The different reasons for disapproving a criterion can be found here:
   // https://support.google.com/adspolicy/answer/6008942
   //
   // This field is read-only.
   repeated string disapproval_reasons = 59
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. The resource names of labels attached to this ad group
   // criterion.
   repeated string labels = 60 [
     (google.api.field_behavior) = OUTPUT_ONLY,
     (google.api.resource_reference) = {
       type: "googleads.googleapis.com/AdGroupCriterionLabel"
     }
   ];

   // The modifier for the bid when the criterion matches. The modifier must be
   // in the range: 0.1 - 10.0. Most targetable criteria types support modifiers.
   optional double bid_modifier = 61;

   // The CPC (cost-per-click) bid.
   optional int64 cpc_bid_micros = 62;

   // The CPM (cost-per-thousand viewable impressions) bid.
   optional int64 cpm_bid_micros = 63;

   // The CPV (cost-per-view) bid.
   optional int64 cpv_bid_micros = 64;

   // The CPC bid amount, expressed as a fraction of the advertised price
   // for some good or service. The valid range for the fraction is [0,1) and the
   // value stored here is 1,000,000 * [fraction].
   optional int64 percent_cpc_bid_micros = 65;

   // Output only. The effective CPC (cost-per-click) bid.
   optional int64 effective_cpc_bid_micros = 66
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. The effective CPM (cost-per-thousand viewable impressions)
   // bid.
   optional int64 effective_cpm_bid_micros = 67
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. The effective CPV (cost-per-view) bid.
   optional int64 effective_cpv_bid_micros = 68
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. The effective Percent CPC bid amount.
   optional int64 effective_percent_cpc_bid_micros = 69
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Source of the effective CPC bid.
-  google.ads.googleads.v16.enums.BiddingSourceEnum.BiddingSource
+  google.ads.googleads.v17.enums.BiddingSourceEnum.BiddingSource
       effective_cpc_bid_source = 21 [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Source of the effective CPM bid.
-  google.ads.googleads.v16.enums.BiddingSourceEnum.BiddingSource
+  google.ads.googleads.v17.enums.BiddingSourceEnum.BiddingSource
       effective_cpm_bid_source = 22 [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Source of the effective CPV bid.
-  google.ads.googleads.v16.enums.BiddingSourceEnum.BiddingSource
+  google.ads.googleads.v17.enums.BiddingSourceEnum.BiddingSource
       effective_cpv_bid_source = 23 [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Source of the effective Percent CPC bid.
-  google.ads.googleads.v16.enums.BiddingSourceEnum.BiddingSource
+  google.ads.googleads.v17.enums.BiddingSourceEnum.BiddingSource
       effective_percent_cpc_bid_source = 35
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Estimates for criterion bids at various positions.
   PositionEstimates position_estimates = 10
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // The list of possible final URLs after all cross-domain redirects for the
   // ad.
   repeated string final_urls = 70;

   // The list of possible final mobile URLs after all cross-domain redirects.
   repeated string final_mobile_urls = 71;

   // URL template for appending params to final URL.
   optional string final_url_suffix = 72;

   // The URL template for constructing a tracking URL.
   optional string tracking_url_template = 73;

   // The list of mappings used to substitute custom parameter tags in a
   // `tracking_url_template`, `final_urls`, or `mobile_final_urls`.
-  repeated google.ads.googleads.v16.common.CustomParameter
+  repeated google.ads.googleads.v17.common.CustomParameter
       url_custom_parameters = 14;

+  // Output only. The primary status for the ad group criterion.
+  optional google.ads.googleads.v17.enums.AdGroupCriterionPrimaryStatusEnum
+      .AdGroupCriterionPrimaryStatus primary_status = 85
+      [(google.api.field_behavior) = OUTPUT_ONLY];
+
+  // Output only. The primary status reasons for the ad group criterion.
+  repeated
+      google.ads.googleads.v17.enums.AdGroupCriterionPrimaryStatusReasonEnum
+          .AdGroupCriterionPrimaryStatusReason primary_status_reasons = 86
+      [(google.api.field_behavior) = OUTPUT_ONLY];
+
   // The ad group criterion.
   //
   // Exactly one must be set.
   oneof criterion {
     // Immutable. Keyword.
-    google.ads.googleads.v16.common.KeywordInfo keyword = 27
+    google.ads.googleads.v17.common.KeywordInfo keyword = 27
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Placement.
-    google.ads.googleads.v16.common.PlacementInfo placement = 28
+    google.ads.googleads.v17.common.PlacementInfo placement = 28
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Mobile app category.
-    google.ads.googleads.v16.common.MobileAppCategoryInfo mobile_app_category =
+    google.ads.googleads.v17.common.MobileAppCategoryInfo mobile_app_category =
         29 [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Mobile application.
-    google.ads.googleads.v16.common.MobileApplicationInfo mobile_application =
+    google.ads.googleads.v17.common.MobileApplicationInfo mobile_application =
         30 [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Listing group.
-    google.ads.googleads.v16.common.ListingGroupInfo listing_group = 32
+    google.ads.googleads.v17.common.ListingGroupInfo listing_group = 32
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Age range.
-    google.ads.googleads.v16.common.AgeRangeInfo age_range = 36
+    google.ads.googleads.v17.common.AgeRangeInfo age_range = 36
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Gender.
-    google.ads.googleads.v16.common.GenderInfo gender = 37
+    google.ads.googleads.v17.common.GenderInfo gender = 37
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Income range.
-    google.ads.googleads.v16.common.IncomeRangeInfo income_range = 38
+    google.ads.googleads.v17.common.IncomeRangeInfo income_range = 38
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Parental status.
-    google.ads.googleads.v16.common.ParentalStatusInfo parental_status = 39
+    google.ads.googleads.v17.common.ParentalStatusInfo parental_status = 39
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. User List.
-    google.ads.googleads.v16.common.UserListInfo user_list = 42
+    google.ads.googleads.v17.common.UserListInfo user_list = 42
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. YouTube Video.
-    google.ads.googleads.v16.common.YouTubeVideoInfo youtube_video = 40
+    google.ads.googleads.v17.common.YouTubeVideoInfo youtube_video = 40
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. YouTube Channel.
-    google.ads.googleads.v16.common.YouTubeChannelInfo youtube_channel = 41
+    google.ads.googleads.v17.common.YouTubeChannelInfo youtube_channel = 41
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Topic.
-    google.ads.googleads.v16.common.TopicInfo topic = 43
+    google.ads.googleads.v17.common.TopicInfo topic = 43
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. User Interest.
-    google.ads.googleads.v16.common.UserInterestInfo user_interest = 45
+    google.ads.googleads.v17.common.UserInterestInfo user_interest = 45
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Webpage
-    google.ads.googleads.v16.common.WebpageInfo webpage = 46
+    google.ads.googleads.v17.common.WebpageInfo webpage = 46
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. App Payment Model.
-    google.ads.googleads.v16.common.AppPaymentModelInfo app_payment_model = 47
+    google.ads.googleads.v17.common.AppPaymentModelInfo app_payment_model = 47
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Custom Affinity.
-    google.ads.googleads.v16.common.CustomAffinityInfo custom_affinity = 48
+    google.ads.googleads.v17.common.CustomAffinityInfo custom_affinity = 48
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Custom Intent.
-    google.ads.googleads.v16.common.CustomIntentInfo custom_intent = 49
+    google.ads.googleads.v17.common.CustomIntentInfo custom_intent = 49
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Custom Audience.
-    google.ads.googleads.v16.common.CustomAudienceInfo custom_audience = 74
+    google.ads.googleads.v17.common.CustomAudienceInfo custom_audience = 74
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Combined Audience.
-    google.ads.googleads.v16.common.CombinedAudienceInfo combined_audience = 75
+    google.ads.googleads.v17.common.CombinedAudienceInfo combined_audience = 75
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Audience.
-    google.ads.googleads.v16.common.AudienceInfo audience = 79
+    google.ads.googleads.v17.common.AudienceInfo audience = 79
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Location.
-    google.ads.googleads.v16.common.LocationInfo location = 82
+    google.ads.googleads.v17.common.LocationInfo location = 82
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. Language.
-    google.ads.googleads.v16.common.LanguageInfo language = 83
+    google.ads.googleads.v17.common.LanguageInfo language = 83
         [(google.api.field_behavior) = IMMUTABLE];
   }
 }