/resources/asset_group_signal.proto

--- v23/resources/asset_group_signal.proto  2026-06-18 21:20:45.000000000 +0000
+++ v24/resources/asset_group_signal.proto  2026-06-18 18:19:59.000000000 +0000
@@ -1,95 +1,113 @@
 // Copyright 2026 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.v23.resources;
+package google.ads.googleads.v24.resources;

-import "google/ads/googleads/v23/common/criteria.proto";
-import "google/ads/googleads/v23/enums/asset_group_signal_approval_status.proto";
+import "google/ads/googleads/v24/common/criteria.proto";
+import "google/ads/googleads/v24/enums/asset_group_signal_approval_status.proto";
 import "google/api/field_behavior.proto";
 import "google/api/resource.proto";

-option csharp_namespace = "Google.Ads.GoogleAds.V23.Resources";
-option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v23/resources;resources";
+option csharp_namespace = "Google.Ads.GoogleAds.V24.Resources";
+option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v24/resources;resources";
 option java_multiple_files = true;
 option java_outer_classname = "AssetGroupSignalProto";
-option java_package = "com.google.ads.googleads.v23.resources";
+option java_package = "com.google.ads.googleads.v24.resources";
 option objc_class_prefix = "GAA";
-option php_namespace = "Google\\Ads\\GoogleAds\\V23\\Resources";
-option ruby_package = "Google::Ads::GoogleAds::V23::Resources";
+option php_namespace = "Google\\Ads\\GoogleAds\\V24\\Resources";
+option ruby_package = "Google::Ads::GoogleAds::V24::Resources";

 // AssetGroupSignal represents a signal in an asset group. The existence of a
 // signal tells the performance max campaign who's most likely to convert.
 // Performance Max uses the signal to look for new people with similar or
 // stronger intent to find conversions across Search, Display, Video, and more.
 message AssetGroupSignal {
   option (google.api.resource) = {
     type: "googleads.googleapis.com/AssetGroupSignal"
     pattern: "customers/{customer_id}/assetGroupSignals/{asset_group_id}~{criterion_id}"
   };

   // Immutable. The resource name of the asset group signal.
   // Asset group signal resource name have the form:
   //
   // `customers/{customer_id}/assetGroupSignals/{asset_group_id}~{signal_id}`
   string resource_name = 1 [
     (google.api.field_behavior) = IMMUTABLE,
     (google.api.resource_reference) = {
       type: "googleads.googleapis.com/AssetGroupSignal"
     }
   ];

   // Immutable. The asset group which this asset group signal belongs to.
   string asset_group = 2 [
     (google.api.field_behavior) = IMMUTABLE,
     (google.api.resource_reference) = {
       type: "googleads.googleapis.com/AssetGroup"
     }
   ];

   // Output only. Approval status is the output value for search theme signal
   // after Google ads policy review. When using Audience signal, this field is
   // not used and will be absent.
-  google.ads.googleads.v23.enums.AssetGroupSignalApprovalStatusEnum
+  google.ads.googleads.v24.enums.AssetGroupSignalApprovalStatusEnum
       .AssetGroupSignalApprovalStatus approval_status = 6
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // Output only. Computed for SearchTheme signals.
   // When using Audience signal, this field is not used and will be absent.
   repeated string disapproval_reasons = 7
       [(google.api.field_behavior) = OUTPUT_ONLY];

   // The signal of the asset group.
   oneof signal {
     // Immutable. The audience signal to be used by the performance max
     // campaign.
-    google.ads.googleads.v23.common.AudienceInfo audience = 4
+    google.ads.googleads.v24.common.AudienceInfo audience = 4
         [(google.api.field_behavior) = IMMUTABLE];

     // Immutable. The search_theme signal to be used by the performance max
     // campaign.
     // Mutate errors of search_theme criterion includes
     // AssetGroupSignalError.UNSPECIFIED
     // AssetGroupSignalError.UNKNOWN
     // AssetGroupSignalError.TOO_MANY_WORDS
     // AssetGroupSignalError.SEARCH_THEME_POLICY_VIOLATION
     // FieldError.REQUIRED
     // StringFormatError.ILLEGAL_CHARS
     // StringLengthError.TOO_LONG
     // ResourceCountLimitExceededError.RESOURCE_LIMIT
-    google.ads.googleads.v23.common.SearchThemeInfo search_theme = 5
+    google.ads.googleads.v24.common.SearchThemeInfo search_theme = 5
+        [(google.api.field_behavior) = IMMUTABLE];
+
+    // Immutable. The local services signal to be used by the performance max
+    // campaign.
+    google.ads.googleads.v24.common.LocalServiceIdInfo local_services_id = 8
+        [(google.api.field_behavior) = IMMUTABLE];
+
+    // Immutable. The list of vertical ads item group rules used to select items
+    // from the attached vertical feed.
+    //
+    // This field links to a SharedSet of type
+    // VERTICAL_ADS_ITEM_GROUP_RULE_LIST. The rules within the linked SharedSet
+    // define which items from the TRAVEL_FEED AssetSet are eligible to be
+    // served. Items that do not match the rules will be excluded. This behavior
+    // is different from other signal types, which provide guidance to the
+    // optimization engine rather than determining item eligibility.
+    google.ads.googleads.v24.common.VerticalAdsItemGroupRuleListInfo
+        vertical_ads_item_group_rule_list = 9
         [(google.api.field_behavior) = IMMUTABLE];
   }
 }