/services/ad_service.proto

--- v16/services/ad_service.proto   2024-02-22 08:40:46.000000000 +0000
+++ v17/services/ad_service.proto   2024-05-29 15:59:05.000000000 +0000
@@ -1,188 +1,162 @@
-// 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.services;
+package google.ads.googleads.v17.services;

-import "google/ads/googleads/v16/common/policy.proto";
-import "google/ads/googleads/v16/enums/response_content_type.proto";
-import "google/ads/googleads/v16/resources/ad.proto";
+import "google/ads/googleads/v17/common/policy.proto";
+import "google/ads/googleads/v17/enums/response_content_type.proto";
+import "google/ads/googleads/v17/resources/ad.proto";
 
import "google/api/annotations.proto";
 
import "google/api/client.proto";
 
import "google/api/field_behavior.proto";
 
import "google/api/resource.proto";
 
import "google/protobuf/field_mask.proto";
 
import "google/rpc/status.proto";

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

 
// Proto file describing the  Ad service.

 
// Service to manage ads.
 service
AdService {
   option
(google.api.default_host) = "googleads.googleapis.com";
   option
(google.api.oauth_scopes) = "https://www.googleapis.com/auth/adwords";

-  // Returns the requested ad in full detail.
-  //
-  // List of thrown errors:
-  //   [AuthenticationError]()
-  //   [AuthorizationError]()
-  //   [HeaderError]()
-  //   [InternalError]()
-  //   [QuotaError]()
-  //   [RequestError]()
-  rpc GetAd(GetAdRequest) returns (google.ads.googleads.v16.resources.Ad) {
-    option (google.api.http) = {
-      get: "/v16/{resource_name=customers/*/ads/*}"
-    };
-    option (google.api.method_signature) = "resource_name";
-  }
-
   
// Updates ads. Operation statuses are returned. Updating ads is not supported
   
// for TextAd, ExpandedDynamicSearchAd, GmailAd and ImageAd.
   
//
   
// List of thrown errors:
   
//   [AdCustomizerError]()
   
//   [AdError]()
   
//   [AdSharingError]()
   
//   [AdxError]()
   
//   [AssetError]()
   
//   [AssetLinkError]()
   
//   [AuthenticationError]()
   
//   [AuthorizationError]()
   
//   [CollectionSizeError]()
   
//   [DatabaseError]()
   
//   [DateError]()
   
//   [DistinctError]()
   
//   [FeedAttributeReferenceError]()
   
//   [FieldError]()
   
//   [FieldMaskError]()
   
//   [FunctionError]()
   
//   [FunctionParsingError]()
   
//   [HeaderError]()
   
//   [IdError]()
   
//   [ImageError]()
   
//   [InternalError]()
   
//   [ListOperationError]()
   
//   [MediaBundleError]()
   
//   [MediaFileError]()
   
//   [MutateError]()
   
//   [NewResourceCreationError]()
   
//   [NotEmptyError]()
   
//   [NullError]()
   
//   [OperatorError]()
   
//   [PolicyFindingError]()
   
//   [PolicyViolationError]()
   
//   [QuotaError]()
   
//   [RangeError]()
   
//   [RequestError]()
   
//   [SizeLimitError]()
   
//   [StringFormatError]()
   
//   [StringLengthError]()
   
//   [UrlFieldError]()
   rpc
MutateAds(MutateAdsRequest) returns (MutateAdsResponse) {
     option
(google.api.http) = {
-      post: "/v16/customers/{customer_id=*}/ads:mutate"
+      post: "/v17/customers/{customer_id=*}/ads:mutate"
       body
: "*"
     
};
     option
(google.api.method_signature) = "customer_id,operations";
   
}
 
}

 
// Request message for
-// [AdService.GetAd][google.ads.googleads.v16.services.AdService.GetAd].
-message GetAdRequest {
-  // Required. The resource name of the ad to fetch.
-  string resource_name = 1 [
-    (google.api.field_behavior) = REQUIRED,
-    (google.api.resource_reference) = { type: "googleads.googleapis.com/Ad" }
-  ];
-}
-
-// Request message for
-// [AdService.MutateAds][google.ads.googleads.v16.services.AdService.MutateAds].
+// [AdService.MutateAds][google.ads.googleads.v17.services.AdService.MutateAds].
 message
MutateAdsRequest {
   
// Required. The ID of the customer whose ads are being modified.
   
string customer_id = 1 [(google.api.field_behavior) = REQUIRED];

   
// Required. The list of operations to perform on individual ads.
   repeated
AdOperation operations = 2 [(google.api.field_behavior) = REQUIRED];

   
// If true, successful operations will be carried out and invalid
   
// operations will return errors. If false, all operations will be carried
   
// out in one transaction if and only if they are all valid.
   
// Default is false.
   
bool partial_failure = 4;

   
// The response content type setting. Determines whether the mutable resource
   
// or just the resource name should be returned post mutation.
-  google.ads.googleads.v16.enums.ResponseContentTypeEnum.ResponseContentType
+  google.ads.googleads.v17.enums.ResponseContentTypeEnum.ResponseContentType
       response_content_type
= 5;

   
// If true, the request is validated but not executed. Only errors are
   
// returned, not results.
   
bool validate_only = 3;
 
}

 
// A single update operation on an ad.
 message
AdOperation {
   
// FieldMask that determines which resource fields are modified in an update.
   google
.protobuf.FieldMask update_mask = 2;

   
// Configuration for how policies are validated.
-  google.ads.googleads.v16.common.PolicyValidationParameter
+  google.ads.googleads.v17.common.PolicyValidationParameter
       policy_validation_parameter
= 3;

   
// The mutate operation.
   oneof operation
{
     
// Update operation: The ad is expected to have a valid resource name
     
// in this format:
     
//
     
// `customers/{customer_id}/ads/{ad_id}`
-    google.ads.googleads.v16.resources.Ad update = 1;
+    google.ads.googleads.v17.resources.Ad update = 1;
   
}
 
}

 
// Response message for an ad mutate.
 message
MutateAdsResponse {
   
// Errors that pertain to operation failures in the partial failure mode.
   
// Returned only when partial_failure = true and all errors occur inside the
   
// operations. If any errors occur outside the operations (for example, auth
   
// errors), we return an RPC level error.
   google
.rpc.Status partial_failure_error = 3;

   
// All results for the mutate.
   repeated
MutateAdResult results = 2;
 
}

 
// The result for the ad mutate.
 message
MutateAdResult {
   
// The resource name returned for successful operations.
   
string resource_name = 1 [
     
(google.api.resource_reference) = { type: "googleads.googleapis.com/Ad" }
   
];

   
// The mutated ad with only mutable fields after mutate. The field will only
   
// be returned when response_content_type is set to "MUTABLE_RESOURCE".
-  google.ads.googleads.v16.resources.Ad ad = 2;
+  google.ads.googleads.v17.resources.Ad ad = 2;
 
}